国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > PHP > 正文

php加密與解密

2020-03-22 19:52:55
字體:
供稿:網(wǎng)友
  • 參考http://biancheng.dnbcw.info/php/111642.html整理的代碼。

    測試文件

    test.php

    <?php    echo 'hello world.';?>

    1.加密方法:

    <?php/*eval() 函數(shù)字符串按照 PHP 代碼來計算。該字符串必須是合法的 PHP 代碼,且必須以分號結(jié)尾。strtr() 字符替換 把字符串中的字符 'ia' 替換為 'eo':strtr('Hilla Warld','ia','eo');*/function T_rndstr($length = '') { //返回隨機字符串    $str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz';    if ($length == '') {        return str_shuffle($str);    } else {        return substr(str_shuffle($str), -$length);    }}$T_k1 = T_rndstr(); //隨機密匙1$T_k2 = T_rndstr(); //隨機密匙2$vstr = file_get_contents('./test.php'); //要加密的文件$v1 = base64_encode($vstr);$c = strtr($v1, $T_k1, $T_k2); //根據(jù)密匙替換對應(yīng)字符$c = $T_k1 . $T_k2 . $c;//$qn變量功能下面會講解$isqs = 3;if ($isqs == '1') { // 1 取隨機字符串為變量名    $q = T_rndstr(); // 隨機字符串    $q1 = substr($q, 2, 3);    $q2 = substr($q, 10, 10);    $q3 = substr($q, 20, 12);    $q4 = substr($q, 30, 10);    $q5 = substr($q, 40, 8);    $q6 = substr($q, 5, 5);} else if ($isqs == '2') { // 2 為小寫l和1組成,開頭必須是字母    $q1 = 'll11l1l1';    $q2 = 'l1lll11l';    $q3 = 'll1l1lll';    $q4 = 'l1lll1l1';    $q5 = 'l1l1ll11';    $q6 = 'll111l1l';} else { // 大寫O與數(shù)字0組成基本變量    $q1 = 'O00O0O';    $q2 = 'O0O000';    $q3 = 'O0OO00';    $q4 = 'OO0O00';    $q5 = 'OO0000';    $q6 = 'O00OO0';}$keystr = urldecode('%6E1%7A%62%2F%6D%615%5C%76%740%6928%2D%70%78%75%71%79%2A6%6C%72%6B%64%679%5F%65%68%63%73%77%6F4%2B%6637%6A');/* 字符串,里面必須要有變量所需的字符,比如 base64_decoden1zb/ma5t0i28-pxuqy*6lrkdg9_ehcswo4+f37j$q1 = base$q3 = strtr$q4 = substr$q5 = 52 -> ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz 長度$q1 .= 64_decode -> base64_decode*/$s = '$' . $q6 . '=urldecode('%6E1%7A%62%2F%6D%615%5C%76%740%6928%2D%70%78%75%71%79%2A6%6C%72%6B%64%679%5F%65%68%63%73%77%6F4%2B%6637%6A');$' . $q1 . '=$' . $q6 . '{3}.$' . $q6 . '{6}.$' . $q6 . '{33}.$' . $q6 . '{30};$' . $q3 . '=$' . $q6 . '{33}.$' . $q6 . '{10}.$' . $q6 . '{24}.$' . $q6 . '{10}.$' . $q6 . '{24};$' . $q4 . '=$' . $q3 . '{0}.$' . $q6 . '{18}.$' . $q6 . '{3}.$' . $q3 . '{0}.$' . $q3 . '{1}.$' . $q6 . '{24};$' . $q5 . '=$' . $q6 . '{7}.$' . $q6 . '{13};$' . $q1 . '.=$' . $q6 . '{22}.$' . $q6 . '{36}.$' . $q6 . '{29}.$' . $q6 . '{26}.$' . $q6 . '{30}.$' . $q6 . '{32}.$' . $q6 . '{35}.$' . $q6 . '{26}.$' . $q6 . '{30};eval($' . $q1 . '('' . base64_encode('$' . $q2 . '='' . $c . '';eval('?>'.$' . $q1 . '($' . $q3 . '($' . $q4 . '($' . $q2 . ',$' . $q5 . '*2),$' . $q4 . '($' . $q2 . ',$' . $q5 . ',$' . $q5 . '),$' . $q4 . '($' . $q2 . ',0,$' . $q5 . '))));') . ''));';echo $s;file_put_contents('./test_encode.php', '<?php '.$s.'?>');?>

    運行加密后生成test_encode.php文件

    <?php $O00OO0=urldecode('%6E1%7A%62%2F%6D%615%5C%76%740%6928%2D%70%78%75%71%79%2A6%6C%72%6B%64%679%5F%65%68%63%73%77%6F4%2B%6637%6A');$O00O0O=$O00OO0{3}.$O00OO0{6}.$O00OO0{33}.$O00OO0{30};$O0OO00=$O00OO0{33}.$O00OO0{10}.$O00OO0{24}.$O00OO0{10}.$O00OO0{24};$OO0O00=$O0OO00{0}.$O00OO0{18}.$O00OO0{3}.$O0OO00{0}.$O0OO00{1}.$O00OO0{24};$OO0000=$O00OO0{7}.$O00OO0{13};$O00O0O.=$O00OO0{22}.$O00OO0{36}.$O00OO0{29}.$O00OO0{26}.$O00OO0{30}.$O00OO0{32}.$O00OO0{35}.$O00OO0{26}.$O00OO0{30};eval($O00O0O('JE8wTzAwMD0iTGhxQk16QW5Zc29qUlVmSVhKZVBGSFF2Q2FwRWtOVFpHY2lXdWxtYmdkclZ5S3R3RFNPeER2Z2pick1mT1hreXVHaFlTVW5FcFF3b1B0Y2lLQ2VSTkhkWlZhVElGc0FMeGxxV3ptSkJFejlXdFFNQ1BkTUZZUGphTzJ2b1lQVWtSWkJYSXhqM0kzVVhSUDRkSlcwbFl6OCt6d2s9IjtldmFsKCc/PicuJE8wME8wTygkTzBPTzAwKCRPTzBPMDAoJE8wTzAwMCwkT08wMDAwKjIpLCRPTzBPMDAoJE8wTzAwMCwkT08wMDAwLCRPTzAwMDApLCRPTzBPMDAoJE8wTzAwMCwwLCRPTzAwMDApKSkpOw=='));?>

    解析

    <?php// 所有的$O00OO等等都是變量!!!/*將%6E1%7A%62%2F%6D%615%5C%76%740%6928%2D%70%78%75%71%79%2A6%6C%72%6B%64%679%5F%65%68%63%73%77%6F4%2B%6637%6解碼成n1zb/ma5t0i28-pxuqy*6lrkdg9_ehcswo4+f37j并賦值給$O00OO0*/$O00OO0=urldecode('%6E1%7A%62%2F%6D%615%5C%76%740%6928%2D%70%78%75%71%79%2A6%6C%72%6B%64%679%5F%65%68%63%73%77%6F4%2B%6637%6A');// 從$O00OO0及其他變量字符串中獲取對應(yīng)字符后組成新的字符串,并賦值給對應(yīng)的變量// 例如 $O00OO0{3} 代表 n1zb/ma5t0i28-pxuqy*6lrkdg9_ehcswo4+f37j 字符串中的第三個字符,b// $O00O0O = 'base'$O00O0O=$O00OO0{3}.$O00OO0{6}.$O00OO0{33}.$O00OO0{30};// $O0OO00 = 'strtr'$O0OO00=$O00OO0{33}.$O00OO0{10}.$O00OO0{24}.$O00OO0{10}.$O00OO0{24};// $OO0O00 = 'substr'$OO0O00=$O0OO00{0}.$O00OO0{18}.$O00OO0{3}.$O0OO00{0}.$O0OO00{1}.$O00OO0{24};// $OO0000 = '52'$OO0000=$O00OO0{7}.$O00OO0{13};// $O00O0O = 'base64_decode'$O00O0O.=$O00OO0{22}.$O00OO0{36}.$O00OO0{29}.$O00OO0{26}.$O00OO0{30}.$O00OO0{32}.$O00OO0{35}.$O00OO0{26}.$O00OO0{30};// 之后通過eval執(zhí)行php代碼eval($O00O0O('JE8wTzAwMD0iTGhxQk16QW5Zc29qUlVmSVhKZVBGSFF2Q2FwRWtOVFpHY2lXdWxtYmdkclZ5S3R3RFNPeER2Z2pick1mT1hreXVHaFlTVW5FcFF3b1B0Y2lLQ2VSTkhkWlZhVElGc0FMeGxxV3ptSkJFejlXdFFNQ1BkTUZZUGphTzJ2b1lQVWtSWkJYSXhqM0kzVVhSUDRkSlcwbFl6OCt6d2s9IjtldmFsKCc/PicuJE8wME8wTygkTzBPTzAwKCRPTzBPMDAoJE8wTzAwMCwkT08wMDAwKjIpLCRPTzBPMDAoJE8wTzAwMCwkT08wMDAwLCRPTzAwMDApLCRPTzBPMDAoJE8wTzAwMCwwLCRPTzAwMDApKSkpOw=='));/*eval會執(zhí)行后面的PHP代碼第一步為解碼$O00O0O 為 'base64_decode'。即對后面的字符串進行base64解碼JE8wTzAwMD0iTGhxQk16QW5Zc29qUlVmSVhKZVBGSFF2Q2FwRWtOVFpHY2lXdWxtYmdkclZ5S3R3RFNPeER2Z2pick1mT1hreXVHaFlTVW5FcFF3b1B0Y2lLQ2VSTkhkWlZhVElGc0FMeGxxV3ptSkJFejlXdFFNQ1BkTUZZUGphTzJ2b1lQVWtSWkJYSXhqM0kzVVhSUDRkSlcwbFl6OCt6d2s9IjtldmFsKCc/PicuJE8wME8wTygkTzBPTzAwKCRPTzBPMDAoJE8wTzAwMCwkT08wMDAwKjIpLCRPTzBPMDAoJE8wTzAwMCwkT08wMDAwLCRPTzAwMDApLCRPTzBPMDAoJE8wTzAwMCwwLCRPTzAwMDApKSkpOw==解碼后$O0O000='LhqBMzAnYsojRUfIXJePFHQvCapEkNTZGciWulmbgdrVyKtwDSOxDvgjbrMfOXkyuGhYSUnEpQwoPtciKCeRNHdZVaTIFsALxlqWzmJBEz9WtQMCPdMFYPjaO2voYPUkRZBXIxj3I3UXRP4dJW0lYz8+zwk=';eval('?>'.$O00O0O($O0OO00($OO0O00($O0O000,$OO0000*2),$OO0O00($O0O000,$OO0000,$OO0000),$OO0O00($O0O000,0,$OO0000))));第二步是執(zhí)行解碼后的代碼解碼后為另外一份代碼,根據(jù)加密算法可知$O0O000變量的值為密鑰1+密鑰2+源代碼編碼并進行替換后的字符串,這邊先將替換掉的字符串還原回去,之后再進行base64_decode進行解碼,即可獲得原來的代碼!!!注意:由于源代碼已經(jīng)包含<?php ?>,所以這邊必須加入'?>'*/?>

    2.解密方法

    <?php    // 加密的文件格式必須固定!!    /*$O00OO0=urldecode('%6E1%7A%62%2F%6D%615%5C%76%740%6928%2D%70%78%75%71%79%2A6%6C%72%6B%64%679%5F%65%68%63%73%77%6F4%2B%6637%6A');$O00O0O=$O00OO0{3}.$O00OO0{6}.$O00OO0{33}.$O00OO0{30};$O0OO00=$O00OO0{33}.$O00OO0{10}.$O00OO0{24}.$O00OO0{10}.$O00OO0{24};$OO0O00=$O0OO00{0}.$O00OO0{18}.$O00OO0{3}.$O0OO00{0}.$O0OO00{1}.$O00OO0{24};$OO0000=$O00OO0{7}.$O00OO0{13};$O00O0O.=$O00OO0{22}.$O00OO0{36}.$O00OO0{29}.$O00OO0{26}.$O00OO0{30}.$O00OO0{32}.$O00OO0{35}.$O00OO0{26}.$O00OO0{30};eval($O00O0O('JE8wTzAwMD0iTmV5SElCamZRdk......1UYVNuUUpnY21UYVVoOCtoTm89IjtldmFsKCc/=='));?>    */    // 要解密的文件,去掉php標識    $encode_sourcecode = file_get_contents('./test_e.php');    $encode_sourcecode = str_replace('<?php','', $encode_sourcecode);    $encode_sourcecode = str_replace('?>','', $encode_sourcecode);    // 提取第一次需要解密的內(nèi)容    // 即JE8wTzAwMD0iTmV5SElCamZRdk......1UYVNuUUpnY21UYVVoOCtoTm89IjtldmFsKCc/==    echo '</br></br>------------------------------$encode_sourcecode_content</br>';    $start = strripos($encode_sourcecode, '('') + 2;    $end = strripos($encode_sourcecode, '')');    $encode_sourcecode_content = substr($encode_sourcecode, $start, $end - $start);    echo $encode_sourcecode_content;    // 解密加密部分的代碼后的內(nèi)容    // $O0O000='NeyHIBjfQvDMwo......JoSptgMdl3M3JgSKQTiB0nuh8+hNo='; eval('......OO0000))));    echo '</br></br>------------------------------$decode_sourcecode_content</br>';    $decode_sourcecode_content = base64_decode($encode_sourcecode_content);    echo $decode_sourcecode_content;    // 解密后還是一個加密的代碼,需要再次解碼,所以要再次提取需要被解密的內(nèi)容出來    // 即NeyHIBjfQvDMwo......JoSptgMdl3M3JgSKQTiB0nuh8+hNo=    echo '</br></br>------------------------------$decode_sourcecode_content_encode_content</br>';    $start = stripos($decode_sourcecode_content, ''') + 1;    $end = strripos($decode_sourcecode_content, ''') ;    $decode_sourcecode_content_encode_content = substr($decode_sourcecode_content, $start, $end - $start);    echo $decode_sourcecode_content_encode_content;    // 根據(jù)加密規(guī)則,替換字符并解碼,即可得到原文件    echo '</br></br>------------------------------$decode_sourcecode_content_encode_content</br>';    $origin_content = base64_decode(strtr(        substr($decode_sourcecode_content_encode_content, 104),        substr($decode_sourcecode_content_encode_content, 52, 52),        substr($decode_sourcecode_content_encode_content, 0, 52)));    var_dump($origin_content);    file_put_contents('./test_origin.php', $origin_content); ?>

    urldecode可以到http://tool.chinaz.com/tools/urlencode.aspx進行解碼

    PHP編程

    鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

  • 發(fā)表評論 共有條評論
    用戶名: 密碼:
    驗證碼: 匿名發(fā)表
    主站蜘蛛池模板: 蓬溪县| 舞阳县| 原平市| 太白县| 咸丰县| 交城县| 娄烦县| 普格县| 宣武区| 安溪县| 北安市| 东台市| 东源县| 岳阳市| 寻乌县| 富锦市| 红桥区| 万宁市| 健康| 钟山县| 榆树市| 永川市| 丹巴县| 林甸县| 丹江口市| 东乡族自治县| 陆良县| 玉树县| 阜平县| 东乌| 新平| 府谷县| 织金县| 梁山县| 卓尼县| 东山县| 马鞍山市| 耿马| 盐池县| 南丹县| 东山县|