메뉴 건너뛰기

조회 수 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
번호 제목 날짜 조회 수
37 리눅스 보안 Tip 2014.02.27 8785
36 Apache 2.2.17 + WebLogic 10.3.3 연동하기 2016.11.22 8795
35 하드디스크 배드블록 점검 툴 - badblocks 2016.03.18 8808
34 chkrootkit 0.49 설치 및 사용법 그리고 변조파일 정상 복원 2014.03.26 8869
33 Apache Mod_Security 사용방법 2016.04.22 8916
32 인코딩 깨진한글파일 삭제 방법 file 2016.07.22 8955
31 rsync ssh를 이용한 서버 백업 2016.03.18 9006
30 포그라운드, 백그라운드, nohup 정리 2017.04.18 9043
29 hp Smart Array CLI 사용해서 논리드라이브 복구(Linux) 2015.06.16 9058
28 아파치(apache) 한글 URL 인식 모듈 설치 file 2016.07.22 9123
27 리눅스 SSH 로그인 점검 2016.07.26 9147
26 Nikto - 웹 취약점 스캐너 도구 file 2016.04.22 9232
25 vsftp 이란? 2014.02.27 9258
24 확장자가 없는 파일 자동인식하는 mod_mime_magic 2016.03.18 9316
23 kernel panic 복구 2014.02.27 9320
22 시스템 보안점검 명령어들 file 2015.07.08 9372
21 아파치(apache) 한글 URL 인식 모듈 설치 file 2016.07.22 9435
20 MySQL Linux Port 방화벽 설정(3306) file 2017.03.11 9468
19 [CentOS 6.5] Tomcat 설치 및 구동 file 2017.03.11 9483
18 iptable에서 TCP SYN Flooding 차단 설정 2014.02.27 9555
Board Pagination Prev 1 ... 3 4 5 6 7 8 9 10 11 12 Next
/ 12

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved