메뉴 건너뛰기

조회 수 1420 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

PHP 소스를 암호화 하는 경우는 mysql 접속 계정이 들어있는 파일이나 ftp 접속 계정, 계정 생성 암호화 방식, DB테이블 구조 등 여러가지 이유에서 소스를 아무도 열어볼 수 없게 하고 싶을 때 입니다.

일반적으로 소스 파일을 열어보면 누구나 쉽게 내용을 볼 수 가 있죠. 이것을 바이너리 파일로 변환하여 알아볼 수 없게 만듭니다.

그러나 파일자체로서는 동작을 합니다.

(중요) 소스를 암호화 하면 내용을 복호화 하지 못하므로, 개발자는 암호화되기전의 원본 소스 파일을 별도로 보관해야 합니다.

그럼 사용방법을 알아보도록 하겠습니다.

 

1. 다운로드

# cd /usr/local/src
# wget wget –no-check-certificate http://sourceforge.net/projects/php-screw/files/php-screw/1.5/php_screw-1.5.tar.gz

 

2. 설치

# cd php_screw-1.5
# /usr/local/php/bin/phpize
# ./configure –with-php-config=/usr/local/php/bin/php-config
# make

make 명령에서 에러날 경우

/usr/local/src/php_screw-1.5/php_screw.c: In function ‘pm9screw_compile_file’:

/usr/local/src/php_screw-1.5/php_screw.c:78: error: too few arguments to function ‘org_compile_file’

/usr/local/src/php_screw-1.5/php_screw.c:84: error: too few arguments to function ‘org_compile_file’

/usr/local/src/php_screw-1.5/php_screw.c:93: error: too few arguments to function ‘org_compile_file’

make: *** [php_screw.lo] 오류 1

php_screw.c 파일의 78,84,93 라인을 수정해줍니다.

org_compile_file(file_handle, type);                       // 수정 전

org_compile_file(file_handle, type TSRMLS_CC);    // 수정 후

그리고 make clean, 다시 make 를 진행합니다.

# make clean
# make 
# make install
# cp -arp /usr/local/php/lib/php/extensions/no-debug-zts-20060613/php_screw.so /usr/local/php/lib/

 

3. 설정 

# vi /usr/local/apache/conf/php.ini

extension_dir = “/usr/local/php/lib”

extension = “php_screw.so”

apache 를 재시작하여 적용합니다.

# /usr/local/apache/bin/apachectl restar

 

4. 명령어 복사

# cd tools
# make
# cp -arp screw /usr/bin/

 

5. 사용 방법

이제 PHP 소스 파일을 암호화 할 수 있습니다.

적용 방식은 아래와 같습니다.

예) screw phpinfo.php

결과) phpinfo.php 는 암호화 처리되며, 원본파일은 phpinfo.php.screw 로 남게 됩니다.


List of Articles
번호 제목 날짜 조회 수
237 ftp passive mode 설정 2014.02.27 8095
236 APM 소스 설치 2014.02.27 8068
235 APM 소스 설치 2014.02.27 7736
234 vsftp 이란? 2014.02.27 9258
233 파일 속성 명령어 : chattr, lsattr 2014.02.27 9622
232 history 파일 삭제 제한하기 2014.02.27 7788
231 apache + mysql 자동 실행 방법 (소스설치) 2014.02.27 7966
230 도메인 포워딩 설정 2014.02.27 7970
229 리눅스 보안 Tip 2014.02.27 8785
228 SQL 인젝션 복구 쿼리 2014.02.27 8248
227 외부에서 apache 정보 못보도록 설정하기 2014.02.27 8013
226 도메인에 자동으로 www 붙도록 설정하기 2014.02.27 7581
225 htaccess를 이용한 특정 디렉토리 접근 관리하기 2014.02.27 7136
224 iptable에서 TCP SYN Flooding 차단 설정 2014.02.27 9555
223 yum rpmforge 등록하기 2014.02.27 7806
222 iptables GEOIP 모듈 설치. (국가별 IP 차단) 2014.02.27 7868
221 tmp 보안 셋팅 2014.02.27 7086
220 Linux LVM구성하기 2014.02.27 8218
219 CentOS 32Bit 운영체제에서 메모리 4G인식 시키는 방법 2014.02.27 7103
218 suPHP로 웹서버 보안을 강화하자 2014.02.27 8781
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 12 Next
/ 12

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved