메뉴 건너뛰기

조회 수 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
번호 제목 날짜 조회 수
117 mariadb | my.cnf 설정. MariaDB(5.5.37) utf8 설정 2015.07.16 7711
116 CentOS 7 에 php 설치하기 2015.07.16 7663
115 CentOS 7 에 아파치(httpd) 설치 2015.07.16 10310
114 아파치 설치 2015.07.16 7864
113 시스템 보안점검 명령어들 file 2015.07.08 9372
112 리눅스 계정 파일 위치 file 2015.07.01 8117
111 hp Smart Array CLI 사용해서 논리드라이브 복구(Linux) 2015.06.16 9058
110 fdisk로 파티션 삭제하기 2015.06.10 26101
109 sulinux2.0 NFS 설정 & 공유 2015.06.10 7943
108 리눅스 마운트 (mount)를 해보자 file 2015.06.09 8529
107 리눅스 파티션(partition)을 나눠보자 file 2015.06.09 8438
106 fdisk로 파티션 삭제하기 2015.06.09 21723
105 리눅스,사용자계정(관련 파일,명령어) file 2014.10.30 7624
104 리눅스 기본보안설정(13) file 2014.05.15 7297
103 리눅스 기본보안설정(12) file 2014.05.15 7900
102 리눅스 기본보안설정(11) file 2014.05.15 8346
101 리눅스 기본보안설정(10) file 2014.05.15 7742
100 리눅스 기본보안설정(9) file 2014.05.15 7514
99 리눅스 기본보안설정(1-8) 2014.05.15 7636
98 문자셋 설정, charset 2014.04.29 7480
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 11 12 Next
/ 12

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved