찾다
백엔드 개발PHP 튜토리얼PHP 코드 암호화 및 복호화

php 코드 암호화 클래스
  1. /*
  2. * @auther:wangyaofeng
  3. * @time:2014.11.6
  4. * @action: php 프로젝트를 암호화합니다. 프로젝트에 프레임워크 디렉토리나 암호화할 필요가 없는 디렉토리가 있으면 미리 옮겨주세요
  5. * */
  6. class Encryption{
  7. private $ c='';//저장 비밀번호 텍스트
  8. private $s='',$q1,$q2,$q3,$q4,$q5,$q6;//생성된 암호화된 파일 내용 저장
  9. / /값을 설정하지 않으면 isset은 해당 값이 존재하지 않는다고 표시합니다.
  10. private $file='';//파일을 읽을 경로
  11. private $source='',$target=' ';
  12. //생성자, 전역 변수 초기화 호출
  13. public function __construct(){
  14. //전역 변수 초기화
  15. $this->initialVar(); /echo "hello n";
  16. }
  17. /*
  18. *@input $property_name,$value
  19. *@output
  20. * 변수 값을 설정하는 매직 메소드; 필요에 따라. if 판단이 직접 제거되면 존재하지 않는 속성을 포함하여 모든 속성의 값을 설정할 수 있음을 의미합니다.
  21. */
  22. public function __set($property_name,$value){
  23. / /정의된 변수;
  24. if(isset($this->$property_name)){
  25. $this->$property_name = $value;
  26. }else{
  27. //예외 처리 선언되지 않은 변수 할당은 필요에 따라 처리될 수 있습니다.
  28. throw new Exception("속성이 존재하지 않습니다");
  29. }
  30. }
  31. //변수 값을 가져오는 마법의 메서드
  32. public function __get($property_name){
  33. if (isset($this->$property_name)){
  34. return $this->$property_name;
  35. }else{
  36. //새 예외 발생("속성이 존재하지 않습니다") ;
  37. return NULL; }
  38. }
  39. //무작위 정렬 가져오기
  40. 비공개 함수 RandAbc($length=""){//무작위 정렬 가져오기
  41. $str="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz ";
  42. return str_shuffle($str);
  43. }
  44. //일반 텍스트 콘텐츠 암호화
  45. private function ciphertext($filename){
  46. //$filename='index.php' ;
  47. $T_k1=$this->RandAbc();
  48. $T_k2=$this->RandAbc()
  49. $vstr=file_get_contents($filename); ( $vstr);
  50. $c=strtr($v1,$T_k1,$T_k2)
  51. $this->c=$T_k1.$T_k2.$c; 🎜 > }
  52. //변수 초기화
  53. private functioninitialVar(){
  54. $this->q1="O00O0O";//base64_decode
  55. $this->q2="O0O000"; / /$c (strtr 대체 후 원본 텍스트의 암호문, 대상 문자 대체 문자 base64_encode('원본 텍스트 콘텐츠')로 구성됨)
  56. $this->q3="O0OO00";//strtr
  57. $this- >q4="OO0O00";//substr
  58. $this->q5="OO0000";//52
  59. $this->q6="O00OO0";//urldecode 구문 분석됨 string (n1zb/ma5vt0i28-pxuqy*6lrkdg9_ehcswo4 f37j)
  60. }
  61. //암호화된 템플릿 생성(복잡한 버전)
  62. private function model(){
  63. //$c = $ this ->c
  64. //$this->initialVar();
  65. $this->s='q6.'=urldecode(" n1zb /ma5vt0i28-pxuqy*6lrkdg9_ehcswo4+f37j");$'.
  66. $this->q1.'=$'.$this->q6.'{3}.$'.$this-> q6 .'{6}.$'.$this->q6.'{33}.$'.$this->q6.'{30};$'.$this->q3.'=$ ' .$this->q6.'{33}.$'.$this->q6.'{10}.$'
  67. .$this->q6.'{24}.$'. this->q6.'{10}.$'.$this->q6.'{24};$'.$this->q4.'=$'.$this->q3.' 0}.$'.$this->q6.'{18}.$'.$this->q6.'{3}.$'.$this->q3.'{0}
  68. .$'.$this->q3.'작은贝.$'.$this->q6.'{24};$'.$this->q5.'=$'.$this-> ; q6.'{7}.$'.$this->q6.'{13};$'.$this->q1.'.=$'.$this->q6.'{22} . $'.$this->q6.'{36}
  69. .$'.$this->q6.'{29}.$'.$this->q6.'{26}.$ ' .$this->q6.'{30}.$'.$this->q6.'{32}.$'.$this->q6.'{35}.$'.$this- > ;q6.'{26}.$'.$this->q6.'{30};
  70. eval($'.$this->q1.'("'.base64_encode('$'. $ this->q2.'="'.$this->c.'"
  71. eval('?>'.$'.$this->q1.'($'.$this - >q3.'($'.$this->q4.'($'.$this->q2.',$'.$this->q5.'*2),$'.$ this ->q4.'($'.$this->q2.',$'.$this->q5.',$'.$this->q5.'),
  72. $' . $this->q4.'($'.$this->q2.',0,$'.$this->q5.'))));').'"));?> ';
  73. return $this;
  74. }
  75. //암호화된 파일 생성
  76. private function build($target){
  77. //$this->encodes("./index.php ");
  78. //$this->model();
  79. $fpp1 = fopen($target,'w');
  80. fwrite($fpp1,$this->s) 또는 사망 ('글쓰기 실패!');
  81. fclose($fpp1);
  82. return $this;
  83. }
  84. //암호화 처리 일관성
  85. public function encode($file,$target){
  86. / /$file = "index.php";
  87. //연속연산은 실제로 처리 후 자신에게 돌아가는 함수를 사용하는 것입니다.
  88. $this->ciphertext($file)->model()-> ;build( $target);
  89. echo 'encode------'.$target.'-----ok
    '
  90. }
  91. //암호화
  92. public function decode($file,$target=''){
  93. //복호화할 파일 읽기
  94. $fpp1 = file_get_contents($file)
  95. $this->decodeMode($fpp1 )-> ;build($target);
  96. echo 'decode------'.$target.'------ok
    '; 템플릿 복호화, 복호화된 텍스트 가져오기
  97. private function decodeMode($fpp1){
  98. //eval을 플래그로 사용하여 배열로 가로채기 첫 번째 절반은 암호 텍스트에서 대체된 함수 이름이고 두 번째는 half는 암호문입니다
  99. $m =explore('eval',$fpp1);
  100. //시스템 함수의 대체 부분을 실행하고 시스템 변수를 가져옵니다
  101. $varStr = substr($m[0 ],strpos($m[0 ],'$'));
  102. //실행 후 대체된 시스템 함수 이름을 사용할 수 있습니다.
  103. eval($varStr)
  104. //있는지 판단합니다. ciphertext
  105. if( !isset($m[1])){
  106. return $this
  107. }
  108. //암호문 가로채기 {$this->q4} substr
  109. $star = strripos($m[1],'(');
  110. $end = strpos($m[1],')')
  111. $str = ${$this->q4 }($m [1],$star,$end)
  112. //암호문 {$this->q1} base64_decode
  113. $str = ${$this->q1}($str );
  114. //복호화된 핵심 암호문 가로채기
  115. $evallen = strpos($str,'eval')
  116. $str = substr($str,0,$evallen); 핵심 암호문을 실행하면 시스템 변수에 $O0O000 값이 할당됩니다.
  117. eval($str)
  118. //${$this->qn}이 작동하지 않기 때문에 다음 단락을 캡슐화할 수 없습니다. 전체 텍스트
  119. $this->s = ${$this->q1}(
  120. ${$this->q3}(
  121. ${$this->q4}(
  122. $ {$this->q2},${$this->q5}*2
  123. ),
  124. ${$this->q4}(
  125. ${$this-> q2} ,${$this->q5},${$this->q5}
  126. ),
  127. ${$this->q4}(
  128. ${$this-> q2} ,0,${$this->q5}
  129. )
  130. )
  131. )
  132. return $this
  133. }
  134. //대상 디렉터리를 반복적으로 읽고 생성합니다. 구조
  135. 비공개 함수 targetDir($target){
  136. if(!empty($target) ) {
  137. if(!file_exists($target)){
  138. mkdir($target,0777,true) ;
  139. }else{
  140. chmod($target,0777);
  141. }
  142. }
  143. }
  144. //지정된 PHP 파일을 복호화하는 재귀 복호화 폴더
  145. 공용 함수 decodeDir($source,$target=""){
  146. if(is_dir($source)){
  147. $this->targetDir($target)
  148. $dir = opendir ($source);
  149. while(false!=$file=readdir($dir))
  150. {
  151. //모든 파일을 나열하고 '.' 및 '..'을 제거합니다. thinkphp 프레임워크이므로 Thinkphp 디렉토리는 기본적으로 제외됩니다.
  152. if($file!='.' && $file!='..' && $file !='ThinkPHP ')
  153. {
  154. $path = $target.DIRECTORY_SEPARATOR.$file
  155. $sourcePath = $source.DIRECTORY_SEPARATOR.$file
  156. $this->decodeDir($sourcePath,$path) ;
  157. }
  158. }
  159. }else if(is_file($source)){
  160. $extension=substr($source,strrpos($source,'.') 1); 🎜> if( strtolower($extension)=='php'){
  161. $this->decode($source,$target)
  162. }else{
  163. //php가 아닌 파일은 처리되지 않음
  164. copy ($source, $target)
  165. }
  166. //return
  167. }
  168. }
  169. //재귀적 암호화는 지정된 폴더의 PHP 파일을 암호화합니다.
  170. public function encodeDir($source,$target){
  171. if(is_dir($source)){
  172. $this-> $target);
  173. $dir = opendir($source);
  174. while(false!=$file=readdir($dir))
  175. {
  176. //모든 파일을 나열하고 '.'을 제거합니다. 그리고 '..'
  177. if($file!='.' && $file!='..' && $file !='ThinkPHP')
  178. {
  179. $path = $target .DIRECTORY_SEPARATOR. $file;
  180. $sourcePath = $source.DIRECTORY_SEPARATOR.$file
  181. $this->encodeDir($sourcePath,$path)
  182. }
  183. }
  184. }else if(is_file($source)){
  185. $extension=substr($source,strrpos($source,'.') 1)
  186. if(strtolower($extension)=='php' ){
  187. $this->encode($source,$target)
  188. }else{
  189. copy($source, $target)
  190. }
  191. }
  192. }
  193. }
  194. $ob = 새 암호화();
  195. $ob->source = "/var/www/bookReservation"
  196. $ob->target = "/var/www/jiami /bookReservation" ;
  197. //지정된 파일의 암호를 해독합니다
  198. //$ob->decode('D:\php\WWW\workspace\weixin2\Application\Home\Controller\IndexController.class.php')
  199. //$ob->decode('jiami.php');
  200. //$ob->decode('dam6.php')
  201. //지정된 파일을 암호화합니다. 디렉토리
  202. $ob->encodeDir($ob->source,$ob->target)
  203. //지정된 파일 디렉토리를 해독합니다
  204. $ob-> decodeDir($ob-> ;target,"/var/www/jiami/bookReservationD")
코드 복사


암호화 및 복호화, PHP


성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
스칼라 유형, 반환 유형, 노조 유형 및 무효 유형을 포함한 PHP 유형의 힌트 작업은 어떻게 작동합니까?스칼라 유형, 반환 유형, 노조 유형 및 무효 유형을 포함한 PHP 유형의 힌트 작업은 어떻게 작동합니까?Apr 17, 2025 am 12:25 AM

PHP 유형은 코드 품질과 가독성을 향상시키기위한 프롬프트입니다. 1) 스칼라 유형 팁 : PHP7.0이므로 int, float 등과 같은 기능 매개 변수에 기본 데이터 유형을 지정할 수 있습니다. 2) 반환 유형 프롬프트 : 기능 반환 값 유형의 일관성을 확인하십시오. 3) Union 유형 프롬프트 : PHP8.0이므로 기능 매개 변수 또는 반환 값에 여러 유형을 지정할 수 있습니다. 4) Nullable 유형 프롬프트 : NULL 값을 포함하고 널 값을 반환 할 수있는 기능을 포함 할 수 있습니다.

PHP는 객체 클로닝 (클론 키워드) 및 __clone 마법 방법을 어떻게 처리합니까?PHP는 객체 클로닝 (클론 키워드) 및 __clone 마법 방법을 어떻게 처리합니까?Apr 17, 2025 am 12:24 AM

PHP에서는 클론 키워드를 사용하여 객체 사본을 만들고 \ _ \ _ Clone Magic 메소드를 통해 클로닝 동작을 사용자 정의하십시오. 1. 복제 키워드를 사용하여 얕은 사본을 만들어 객체의 속성을 복제하지만 객체의 속성은 아닙니다. 2. \ _ \ _ 클론 방법은 얕은 복사 문제를 피하기 위해 중첩 된 물체를 깊이 복사 할 수 있습니다. 3. 복제의 순환 참조 및 성능 문제를 피하고 클로닝 작업을 최적화하여 효율성을 향상시키기 위해주의를 기울이십시오.

PHP vs. Python : 사용 사례 및 응용 프로그램PHP vs. Python : 사용 사례 및 응용 프로그램Apr 17, 2025 am 12:23 AM

PHP는 웹 개발 및 컨텐츠 관리 시스템에 적합하며 Python은 데이터 과학, 기계 학습 및 자동화 스크립트에 적합합니다. 1.PHP는 빠르고 확장 가능한 웹 사이트 및 응용 프로그램을 구축하는 데 잘 작동하며 WordPress와 같은 CMS에서 일반적으로 사용됩니다. 2. Python은 Numpy 및 Tensorflow와 같은 풍부한 라이브러리를 통해 데이터 과학 및 기계 학습 분야에서 뛰어난 공연을했습니다.

다른 HTTP 캐싱 헤더 (예 : 캐시 제어, ETAG, 최종 수정)를 설명하십시오.다른 HTTP 캐싱 헤더 (예 : 캐시 제어, ETAG, 최종 수정)를 설명하십시오.Apr 17, 2025 am 12:22 AM

HTTP 캐시 헤더의 주요 플레이어에는 캐시 제어, ETAG 및 최종 수정이 포함됩니다. 1. 캐시 제어는 캐싱 정책을 제어하는 ​​데 사용됩니다. 예 : 캐시 제어 : Max-AGE = 3600, 공개. 2. ETAG는 고유 식별자를 통해 리소스 변경을 확인합니다. 예 : ETAG : "686897696A7C876B7E". 3. Last-modified는 리소스의 마지막 수정 시간을 나타냅니다. 예 : 마지막으로 변형 : Wed, 21oct201507 : 28 : 00GMT.

PHP에서 보안 비밀번호 해싱을 설명하십시오 (예 : Password_hash, Password_Verify). 왜 MD5 또는 SHA1을 사용하지 않습니까?PHP에서 보안 비밀번호 해싱을 설명하십시오 (예 : Password_hash, Password_Verify). 왜 MD5 또는 SHA1을 사용하지 않습니까?Apr 17, 2025 am 12:06 AM

PHP에서 Password_hash 및 Password_Verify 기능을 사용하여 보안 비밀번호 해싱을 구현해야하며 MD5 또는 SHA1을 사용해서는 안됩니다. 1) Password_hash는 보안을 향상시키기 위해 소금 값이 포함 된 해시를 생성합니다. 2) Password_verify 암호를 확인하고 해시 값을 비교하여 보안을 보장합니다. 3) MD5 및 SHA1은 취약하고 소금 값이 부족하며 현대 암호 보안에는 적합하지 않습니다.

PHP : 서버 측 스크립팅 언어 소개PHP : 서버 측 스크립팅 언어 소개Apr 16, 2025 am 12:18 AM

PHP는 동적 웹 개발 및 서버 측 응용 프로그램에 사용되는 서버 측 스크립팅 언어입니다. 1.PHP는 편집이 필요하지 않으며 빠른 발전에 적합한 해석 된 언어입니다. 2. PHP 코드는 HTML에 포함되어 웹 페이지를 쉽게 개발할 수 있습니다. 3. PHP는 서버 측 로직을 처리하고 HTML 출력을 생성하며 사용자 상호 작용 및 데이터 처리를 지원합니다. 4. PHP는 데이터베이스와 상호 작용하고 프로세스 양식 제출 및 서버 측 작업을 실행할 수 있습니다.

PHP 및 웹 : 장기적인 영향 탐색PHP 및 웹 : 장기적인 영향 탐색Apr 16, 2025 am 12:17 AM

PHP는 지난 수십 년 동안 네트워크를 형성했으며 웹 개발에서 계속 중요한 역할을 할 것입니다. 1) PHP는 1994 년에 시작되었으며 MySQL과의 원활한 통합으로 인해 개발자에게 최초의 선택이되었습니다. 2) 핵심 기능에는 동적 컨텐츠 생성 및 데이터베이스와의 통합이 포함되며 웹 사이트를 실시간으로 업데이트하고 맞춤형 방식으로 표시 할 수 있습니다. 3) PHP의 광범위한 응용 및 생태계는 장기적인 영향을 미쳤지 만 버전 업데이트 및 보안 문제에 직면 해 있습니다. 4) PHP7의 출시와 같은 최근 몇 년간의 성능 향상을 통해 현대 언어와 경쟁 할 수 있습니다. 5) 앞으로 PHP는 컨테이너화 및 마이크로 서비스와 같은 새로운 도전을 다루어야하지만 유연성과 활발한 커뮤니티로 인해 적응력이 있습니다.

PHP를 사용하는 이유는 무엇입니까? 설명 된 장점과 혜택PHP를 사용하는 이유는 무엇입니까? 설명 된 장점과 혜택Apr 16, 2025 am 12:16 AM

PHP의 핵심 이점에는 학습 용이성, 강력한 웹 개발 지원, 풍부한 라이브러리 및 프레임 워크, 고성능 및 확장 성, 크로스 플랫폼 호환성 및 비용 효율성이 포함됩니다. 1) 배우고 사용하기 쉽고 초보자에게 적합합니다. 2) 웹 서버와 우수한 통합 및 여러 데이터베이스를 지원합니다. 3) Laravel과 같은 강력한 프레임 워크가 있습니다. 4) 최적화를 통해 고성능을 달성 할 수 있습니다. 5) 여러 운영 체제 지원; 6) 개발 비용을 줄이기위한 오픈 소스.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경