Skip to content

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

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

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

서론

  php 소스 개발을 하다보면 공개하기가 꺼려지는 소스가 있기 마련입니다. 또한 디비 커넥트 설정과 계정정보 및 서버 설정에 대한 php 소스코드 들은 암호화가 해킹에 대한 최소한의 예방책일 것이다. 이러한 소스 암호화 툴로는 Zend , 이온큐브 쪽 솔루션이 잘 알려져 있습니다. 실제 여러업체에서 사용중이며 안정적입니다. 물론 유료화 버젼입니다. 하지만 무료버전의 암호화 툴도 있습니다. 오픈소스인 php_screw 입니다.
  해당 솔루션은 일본의 ThePM9.com 이라는 개발업체에서 만들어 졌으며, 현재는 1.5버전까지 개발 되어 졌습니다. php 소스코드를 암호화된 파일로 생성하는 실행 파일과 이를 Zend - Compile에 전달 되기전에 해독하는 php 모듈 형태로 이루어 집니다.

  어떠한 방법으로 암호화하는지는 공개 하지 않을 sourceforge를 통해 해당 소스를 다운 받아 php 동적 모듈을 생성 추가 하는 형태 입니다. 아래부터는 해당 모듈의 설치 법에 대해서 알아 보고겠습니다.


본론

1. 설치 조건
  다운 받은 소스상 README 파일을 읽어보시면 알 수 있겠지만 php_screw-1.5버젼은 PHP5.x 버젼에 zlib 이 설치 되어있어야 하며, UNIX 계열 ( 리눅스 , FreeBSD 등) 에서만 지원 합니다. 그런데 php4 버젼에서도 설치 및 운영이 잘됩니다. (당연한 말씀이겠지만 php가 동적으로 설치 되어 있어야 합니다.) 

2. sourceforge를 통해 해당 파일을 다운 받습니다. (http://sourceforge.net/projects/php-screw/)

 

다운이 안되면 첨부파일 php_screw-1.5.tar.gz  이용하세요



3. 저는 해당 소스를 /usr/local/src 디렉토리에 옮겨 놓았습니다.
  [root@localhost src]# pwd
  /usr/local/src
  [root@localhost src]# ls
  php_screw-1.5.tar.gz

4. 소스 압축 해제
  [root@localhost src]# tar xvzf php_screw-1.5.tar.gz 
  php_screw-1.5/
  php_screw-1.5/zencode.c
  php_screw-1.5/LICENSE
  php_screw-1.5/tools/
  php_screw-1.5/tools/zencode.c
  php_screw-1.5/tools/Makefile
  php_screw-1.5/tools/screw.c
  php_screw-1.5/config.h
  php_screw-1.5/README.en
  php_screw-1.5/config.m4
  php_screw-1.5/Makefile.in
  php_screw-1.5/php_screw.c
  php_screw-1.5/php_screw.h
  php_screw-1.5/my_screw.h
  php_screw-1.5/README.jp

5. phpize 명령어를 이용하여 서버 정보에 맞는 configure 생성
  [root@localhost src]# cd php_screw-1.5
  [root@localhost php_screw-1.5]# /usr/local/php/bin/phpize 
  Configuring for:
  PHP Api Version: 20020918
  Zend Module Api No: 20020429
  Zend Extension Api No: 20050606

6. 생성된 소스 확인 
  [root@localhost php_screw-1.5]# ll
  합계 800
  -rw-rw-rw- 1 root root 1388 1월 12 2004 LICENSE
  -rw-r--r-- 1 root root 3151 4월 4 00:10 Makefile.global
  -rw-rw-rw- 1 root root 245 8월 1 2002 Makefile.in
  -rw-rw-rw- 1 root root 4052 10월 14 2007 README.en
  -rw-rw-rw- 1 root root 3290 10월 14 2007 README.jp
  -rw-r--r-- 1 root root 52186 4월 4 00:10 acinclude.m4
  -rw-r--r-- 1 root root 174501 4월 4 00:10 aclocal.m4
  drwxr-xr-x 2 root root 4096 4월 4 00:10 autom4te.cache
  drwxr-xr-x 2 root root 4096 4월 4 00:10 build
  -rwxr-xr-x 1 root root 41134 4월 4 00:10 config.guess
  -rw-r--r-- 1 root root 1644 10월 13 2007 config.h
  -rw-r--r-- 1 root root 1540 4월 4 00:10 config.h.in
  -rw-rw-rw- 1 root root 593 4월 17 2002 config.m4
  -rwxr-xr-x 1 root root 29708 4월 4 00:10 config.sub
  -rwxr-xr-x 1 root root 279525 4월 4 00:10 configure
  -rw-r--r-- 1 root root 2226 4월 4 00:10 configure.in
  -rw-r--r-- 1 root root 0 4월 4 00:10 install-sh
  -rw-r--r-- 1 root root 143988 4월 4 00:10 ltmain.sh
  -rw-r--r-- 1 root root 0 4월 4 00:10 missing
  -rw-r--r-- 1 root root 0 4월 4 00:10 mkinstalldirs
  -rw-rw-rw- 1 root root 63 8월 1 2002 my_screw.h
  -rw-rw-rw- 1 root root 3142 10월 14 2007 php_screw.c
  -rw-rw-rw- 1 root root 194 8월 1 2002 php_screw.h
  drwxrwxrwx 2 root root 4096 10월 14 2007 tools
  -rw-rw-rw- 1 root root 1772 10월 14 2007 zencode.c

7. SEED key 변경
  - README를 잘 읽어보시면 알겠지만 암호화 할때 특정 키값에 따라 암화된 값이 달라집니다.
  그러므로 각자가 원하시는 값으로 변경 하시면 됩니다. my_screw.h 의 배열의 값을 변경 하시면 됩니다.
  값의 크기에 따른 속도 차이는 없다고 합니다.

  [root@localhost php_screw-1.5]# cat my_screw.h
    short pm9screw_mycryptkey[] = {
     11152, 368, 192, 1281, 62
    };

8. 컴파일 환경 설정
  [root@localhost php_screw-1.5]# ./configure --with-php-config=/usr/local/php/bin/php-config

9. 컴파일
  [root@localhost php_screw-1.5]# 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 를 진행합니다.



10. 모듈 확인
  [root@localhost php_screw-1.5]# ll modules/
  합계 32
  -rw-r--r-- 1 root root 721 4월 4 00:25 php_screw.la
  -rwxr-xr-x 1 root root 26781 4월 4 00:25 php_screw.so

11. 모듈 위치 지정
  - 모듈을 확인 하고 make install 을 통해 자동으로 모듈을 특정 디렉토리를 이동 할 수 있지만 경로명이 직관적이지 않아 자체디렉토리를 만들어 줍니다.
  [root@localhost php_screw-1.5]# mkdir /usr/local/lib/php_modules
  [root@localhost php_screw-1.5]# mv modules/php_screw.so /usr/local/lib/php_modules

12. php.ini 설정
  - php.ini 의 설정을 통해 해당 모듈을 로드할 수 있게 합니다. 아래와 같이 
  [root@localhost php_screw-1.5]# vi /usr/local/lib/php.ini
  ......
  extension_dir = "./" 을 extension_dir = "/usr/local/lib/php_modules" 로 수정 및 아래 내용 추가
  extension=php_screw.so
  .....

13. 모듈 확인
  - 아파치 재시작 후 모듈 확인 
  [root@localhost php_screw-1.5]# /usr/local/apache/bin/apachectl restart
  [root@localhost php_screw-1.5]# php -i | grep php_screw
php_screw
php_screw support => enabled
PWD => /usr/local/src/php_screw-1.5
_SERVER["PWD"] => /usr/local/src/php_screw-1.5
_ENV["PWD"] => /usr/local/src/php_screw-1.5
  [root@localhost php_screw-1.5]# 

14. 암호화 명령어 컴파일
  - 모듈 추가가 완료 되면 소스를 암호화하는 툴을 컴파일 해야 합니다.
  해당 소스트 tools 라는 디렉토리에 있습니다.
  [root@localhost php_screw-1.5]# cd tools/
  [root@localhost tools]# pwd
  /usr/local/src/php_screw-1.5/tools

15. 컴파일 및 결과 확인
  [root@localhost tools]# make
  gcc -o screw screw.c zencode.c -lz
  [root@localhost tools]# ll
  합계 24
  -rw-r--r-- 1 root root 105 10월 14 2007 Makefile
  -rwxr-xr-x 1 root root 8644 4월 4 00:34 screw
  -rw-rw-rw- 1 root root 1541 10월 14 2007 screw.c
  -rw-rw-rw- 1 root root 1772 10월 14 2007 zencode.c

16. screw 라는 명려어를 이용해서 암호화하기
  - 사용하기 쉽게 path가 잡혀있는 경로 이동 하기 것이 좋을듯합니다.
  - test.php 자연수를 입력 받아 구구단을 출력하는 소스입니다.
  [root@localhost tools]# mv screw /usr/local/bin
  [root@localhost tools]# cd /home/test/public_html/
  [root@localhost public_html]# ll
  합계 4
  -rw-r--r-- 1 root root 1398 4월 4 00:39 test.php
  [root@localhost public_html]# screw test.php 
  Success Crypting(test.php)
  [root@localhost public_html]# ll
  합계 8
  -rw-r--r-- 1 root root 768 4월 4 00:44 test.php
  -rw-r--r-- 1 root root 1398 4월 4 00:44 test.php.screw

17. 암호화 파일 확인 및 원소스 삭제
  - 위의 결과와 같이 소스이름뒤 .screw 가 붙은 파일이 원 소스이다. 백업 후 삭제 해준다.
  - 암호화 파일 확인
[root@localhost public_html]# cat test.php
PM9SCREW �>;ㅤㅅㅟㅊ,�{�!`�s첨e=�Iㅤㅍㅐㅍ�YU.i*�+ⓘⅴㅤㄷㅘㄻㅤㄲㅑㄷㅤㄷㅜㅋ��|(p�@~B㎎臾;Nx�{uㅤㄱㅢㄻ1ㅤㅈㅙㅅ$ごㅤㅆㅢㄵ�Li�.b��ㅤㅅㅞㅅ厘TH�*�[c�Lf
RbZ�gr統�ㅤㅇㅡㄾt24%#�ㅤㄹㅓㅀ�8�EㅤㅆㅒㅤZ緡v�ㅤㅎㅞㄺㅤㄷㅘㅇ�#_�Mㅤㄲㅘㅊㅤㄷㅙㅍ4n펍岱!
�`ㅤㄸㅙㅀ�h�`�iZHㅤㄱㅘㄾ:s�#�-LTㅤㄲㅣㅍH�3ㅤㄲㅔㄿ狼lㅤㅅㅒㄳ�ㅤㄴㅔㅊㅤㅉㅡㅈ뼘x0ㅤㄱㅏㄲ1�ㅤㄲㅘㅀBEㅤㅁㅣㅀㅤㅆㅒㄼ��tㅤㅎㅣㅌc22%ㅤㅌㅔㅀx�{ㅤㄷㅙㄳ)嗅X窺!st�ㅤㅆㅞㅆ섞ㅤㄲㅖㅂ8�E�[m�*陛�
�*w�gㅤㅌㅛㄺJU1ㅤㅈㅝㄵ�W�I�lT商P'ㅤㄲㅔㄺ�+�|+M�V�76��Yㅤㄴㅑㄵㅤㅇㅡㄾ�ㅤㄲㅖㅁ莩�nr���8c詐yKR�}%A僭r�T�`ㅤㅃㅓㄵ"A�
ㅤㄴㅘㅇ��O�r$LZ쇨mㅤㄹㅕㄻ_�\D7淨ㅤㅋㅕㅊ芟鍋$侘ㅤㄲㅒㄺC�\���%驕W廈ㅤㅍㅐㄶe�Z펫Y�Urㅤㅇㅏㅄ~ㅤㅈㅜㄳ鍋�ㅤㅅㅝㄱ�6� ㅤㅎㅕㄼ�bS沈�Jㅤㄱㅢㅈ�cb ㅤㅂㅒㄵ%ㅤㅎㅝㅅx炡�8;?o筒V1ㅤㅍㅑㄻVy((ㅤㄴㅠㅀㅤㅈㅜㄵ0.BbC
���6崗≫?a-;戾+倜�m�F�6d|Tx/�ㅤㅉㅜㄻㅤㄲㅛㄲㅤㅊㅛㄴ�2ㅤㅈㅐㄻ�ㅤㄹㅠㅆ!�ㅤㄱㅗㅋqRc>匕qo@逋[root@localhost public_html]#


결론

  설치 및 운영에는 특별히 신경 쓴 부분이 없다. 그러나 서버 이전시 문제 되는 부분이 있다. my_screw.h 에 설정된 SEED key 값을 모르게 된다면 아무리 모듈을 만들어도 해당 소스 웹출력이 되지 않습니다. 원 소스 백업이 중요하며 해당 SEED key 값도 백업 해 놓는것도 중요합니다.


-By linux.co.kr 슈퍼짱
출처 : 
http://www.linux.co.kr/home2/board/subbs/board.php?bo_table=lecture&wr_id=1727&sca=1  

저작자 표시

List of Articles
번호 제목 글쓴이 날짜 조회 수
48 php mysql에 insert시 싱글쿼츠(홑따옴표) 입력 처리 (mag... ADMINPLAY 2013.09.07 8983
47 Ubuntu 에서 PHP Screw 컴파일시 에러날 때 ADMINPLAY 2013.09.07 7042
» [php모듈] php 소스 암호화 하기 - php_screw-1.5 file ADMINPLAY 2013.03.26 9632
45 configure: error: utf8_mime2text() has new signature, ... ADMINPLAY 2010.05.18 21999
44 oracle10g + php5.2.11 error [OCIEnvNlsCreate() failed] ADMINPLAY 2010.02.24 71509
43 Warning: Unknown: open(, O_RDWR) failed: No such file ... ADMINPLAY 2010.01.29 19818
42 register_globals 에 따른 서버 변수형 변환 ADMINPLAY 2010.01.09 17918
41 register_globals = off 란? ADMINPLAY 2010.01.09 15591
40 4.1.0이상 php 버전에서 register_globals = Off 일때 기... ADMINPLAY 2010.01.09 15493
39 PHP FreeTDS 사용 (MS-SQL) file ADMINPLAY 2010.01.05 16989
38 Fatal error: Call to undefined function domxml_open_mem() ADMINPLAY 2009.12.31 17409
37 pear 1.9 업그레이드 및 패치설치 ADMINPLAY 2009.12.31 17375
36 PEC HTTP Setup ADMINPLAY 2009.12.31 15994
35 PHP.INI에서의 세션 관련설명 ADMINPLAY 2009.10.19 17551
34 Maximum execution time of 30 seconds exceeded ADMINPLAY 2009.09.28 17440
33 php세션정리 ADMINPLAY 2009.09.19 17245
32 Warning: flock(): supplied argument is not a valid str... ADMINPLAY 2009.09.09 16826
31 PHPMyAdmin - blowfish_secret 해결방법 ADMINPLAY 2009.09.08 16561
30 php컴파일에러(flex) configure: error: cannot find out... ADMINPLAY 2009.08.08 16165
29 PHP - eAccelerator 설치 ADMINPLAY 2009.08.03 15113
Board Pagination Prev 1 2 3 Next
/ 3

Copyright ADMINPLAY corp. All rights reserved.

abcXYZ, 세종대왕,1234

abcXYZ, 세종대왕,1234