• 微信
您当前的位置:首页  > 文章 >  PHP源码批量加密的两段代码!不用安装任何插件即可批量加密!

PHP源码批量加密的两段代码!不用安装任何插件即可批量加密!

作者:admin 时间:2021-07-20 阅读数:27人

此代码只能读取路径里的文件,不能读取路径里的文件夹

<?php
  
 function RandAbc($length = "") { // 返回随机字符串 
  $str = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"; 
  return str_shuffle($str); 
 } 
 function getfile($file_dir = ""){
        $file_list = array();
         
        if(empty($file_dir)){
            echo  "不能为空";
        }else{
            $dir = $file_dir;
       
         
         $list = scandir($dir); // 得到该文件下的所有文件和文件夹
        
        foreach($list as $file){ //遍历,如果不是PHP文件,忽略
            $file_location = $dir."/".$file;//生成路径 
        
            $type = strtolower(substr(strrchr($file_location,"."),1));
             
            if(is_dir($file_location) && $file!="." &&$file!=".."){ //判断是不是文件夹
                 
                getfile($file_location); //继续遍历  
            }
             
            if(is_file($file_location)){
              $file_list[] = $file_location;
            }
         
        }
         
       return $file_list;
        }
    }
$dirstr=getfile("/www/wwwroot/路径");//只能读取路径里的文件,不能读取路径里的文件夹
foreach($dirstr as $v){
 $filename = $v; //要加密的文件 
 $T_k1 = RandAbc(); //随机密匙1 
 $T_k2 = RandAbc(); //随机密匙2 
 $vstr = file_get_contents($filename); 
 $v1 = base64_encode($vstr); 
 $c = strtr($v1, $T_k1, $T_k2); //根据密匙替换对应字符。 
 $c = $T_k1.$T_k2.$c; 
 $q1 = "O00O0O"; 
 $q2 = "O0O000"; 
 $q3 = "O0OO00"; 
 $q4 = "OO0O00"; 
 $q5 = "OO0000"; 
 $q6 = "O00OO0"; 
 $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."))));").""));"; 
  
 $s = "<?php "."/n".$s."/n"." ?>"; 
 //echo $s; 
 // 生成 加密后的PHP文件 
 $fpp1 = fopen($filename, "w"); 
 fwrite($fpp1, $s) or die("写文件错误"); 
 echo $filename."加密完成";
}
 ?>

下面的这段代码可以读取文件夹里的所有文件夹下的PHP文件

<?php
 
/**
 *  加密PHP 文件,加密后的PHP代码无需第三方工具解密,像往常一样,直接运行,不需要另外安装扩展
 *  
 * @author Jimmy Fu hxzx@qq.com 
 * @copyright 2016-1-12 
 */
  
ini_set("display_errors", "1");
error_reporting(E_ALL ^ E_NOTICE); 
set_time_limit(0);
header("Content-type:text/html;charset=utf-8"); //调用函数 
//$source_php_folder = "D:/masterphp/renrenrong/app/controller";
$source_php_folder = "/www/wwwroot/111";
//$encode_php_folder = "D:/masterphp/code-test/test";
$encode_php_folder = "/www/winf/192.168.0.139/ceshi2";
phpfileEncode::$is_rewrite = true;  //是否直接加密后替换源文件
$code = new phpfileEncode($source_php_folder,$encode_php_folder);
 
//$filename = "D:/masterphp/code-test/sort.php";
//$toFilename = "D:/masterphp/code-test/test3.php";
//$ret = $code->encodeOneFile($filename,$toFilename="");  //加密单个文件
//var_dump($ret);
//exit;
 
$list = $code->encode();
exit;function pr($var){
     
    echo "<pre>";
    print_r($var);
    echo "</pre>";
     
}
function randAbc($length = "") { // 返回随机字符串 
     $str = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"; 
     return str_shuffle($str); 
}  
 
/**
 *  加密方法类
 * 
 */
class phpCodeEncode {
     
     
    /**
     *  加密方式1
     */
     static public function encode($source){
         
         $contents = $source;  
 
         // 去除PHP头部和尾部标识 
         $headerPos = strpos($contents,"<?php"); 
         $footerPos = strrpos($contents,"?>"); 
         $contents = substr($contents, $headerPos + 5, $footerPos – $headerPos); 
         $encode = base64_encode(gzdeflate($contents)); // 开始编码 
         $encode = "<?php"."/n eval(gzinflate(base64_decode(".""".$encode.""".")));/n/n?>";
         return $encode;
    }
     /**
     *  加密方式2
     */
    static public function encode2($source){
     
         $T_k1 = randAbc(); //随机密匙1 
         $T_k2 = randAbc(); //随机密匙2 
         $v1 = base64_encode($source); 
         $c = strtr($v1, $T_k1, $T_k2); //根据密匙替换对应字符。 
         $c = $T_k1.$T_k2.$c; 
         $q1 = "O00O0O"; 
         $q2 = "O0O000"; 
         $q3 = "O0OO00"; 
         $q4 = "OO0O00"; 
         $q5 = "OO0000"; 
         $q6 = "O00OO0"; 
         $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."))));").""));"; 
     
         $s = "<?php "."/n".$s."/n"." ?>"; 
          
         return $s;
    }
     
     
}
 
     
class phpfileEncode{
     
     static public $source_php_folder; //PHP 项目路径
      
     static public $encode_php_folder; //php 加密后的文件路径
      
     static public $is_rewrite = false; //加密后是否覆盖源文件,默认不覆盖
     
     
    /** 
     *  初始化
     */   
    public function __construct($source_php_folder ,$encode_php_folder = ""){
         
        if(empty($source_php_folder)){
            exit("param $source_php_folder not empty!");
        }   
        self::$source_php_folder = $source_php_folder;
        if( !is_dir($source_php_folder) ){
            exit(""".$source_php_folder."" is not a folder!");
        }
         
        /**
         *  如果单独加密,不覆盖源文件
         */
        if(!self::$is_rewrite){
             /**
             *  如果加密后的文件不制定,则目录下新建目录
             */
            if(empty($encode_php_folder)){
                $folderName = basename(self::$source_php_folder);
                self::$encode_php_folder = dirname(self::$source_php_folder)."/".$folderName."_jiami";
                 
            }else{ 
                //如果不为空,那么
                self::$encode_php_folder = $encode_php_folder;
            }
         
            if(!file_exists(self::$encode_php_folder)){
                if(!is_writable(dirname(self::$source_php_folder))){
                    exit("文件夹没有写权限,path:"".self::$encode_php_folder.""");
                }
                mkdir(self::$encode_php_folder,0777,true); //创建文件夹
            }
             
             
        }else{
              self::$encode_php_folder = $source_php_folder;
        }
        
    }
     
    /**
     *  批量加密,
     * 
     */
    public function encode(){
         
        $encode_false_file = $copy_false_file = array();
        $encode_ok_num = 0;
       $fileList = $this->getFolderFiles();
       
       foreach($fileList as $filepath){
            echo $filepath; echo "<br>";
            $newfilepath = str_replace(self::$source_php_folder,self::$encode_php_folder,$filepath);
            
            $newfilepathdir = dirname($newfilepath);
            if(!file_exists($newfilepathdir)){
                 mkdir($newfilepathdir,0777,true);  //创建文件夹
            }
             
            if(!self::$is_rewrite){
                 //如果是PHP文件则直接加密,如果是非PHP文件,则执行拷贝
                $type=strtolower(substr(strrchr($filepath,"."),1)); 
                if($type == "php"){
                     
                    $ret = $this->encodeOneFile($filepath,$newfilepath);
                }else{
                    //直接拷贝
                    $ret_cp = copy($filepath,$newfilepath);
                    if(!$ret_cp){
                        echo "$filepath,拷贝失败!<br>/n";
                        $copy_false_file[$filepath] = array("newpath"=>$newfilepath);
                    }
                }
            }else{
                    
                //执行加密
               $ret = $this->encodeOneFile($filepath,$newfilepath);
         
            }
            
                 
         
          if(isset($ret) && $ret){
             $encode_ok_num++;
             echo "$filepath,加密成功!<br>/n";
             
          }else{
             $encode_false_file[$filepath] = array("newpath"=>$newfilepath);
          }
          
           
       }
        //有拷贝失败的
       if(!empty($copy_false_file)){
         echo "有失败的拷贝文件";
         pr($copy_false_file);
       } 
        
        
       if(!empty($encode_false_file)){
            pr($encode_false_file);
       }else{
            echo "全部加密成功,一共加密完成(".$encode_ok_num.")个文件";
       }
        
          
         
    }
     
 
     
    /** 
     *  加密一个文件
     *  @param string  $filename  加密源路径
     *  @param string  $toFilename 加密后的文件路径
     *  
     */
    public function encodeOneFile($filename,$toFilename=""){
       
        if(empty($filename)){
            return false;
        }
        if(empty($toFilename)){
            $name = basename($filename,".php"); 
            $new_name = $name."_jiami.php";
            $toFilename = dirname(__FILE__)."/".$new_name;
            
        }
        return $encode_ret = $this->encodeFileContents($filename,$toFilename);
    }
     
     /**
      *  对PHP源文件加密并输出
      * 
      */
     public function encodeFileContents($filename,$toFilename="") { 
         if(self::$is_rewrite){
            $toFilename = $filename;
         }
          
         //如果不可写,则输出
         if(!is_writable($toFilename)){
            exit("目标文件不可写,paht:".$toFilename);
         }
          
         $type=strtolower(substr(strrchr($filename,"."),1)); 
         if ("php" == $type && is_file($filename) && is_writable($toFilename)) { // 如果是PHP文件 并且可写 则进行压缩编码 
             $contents = file_get_contents($filename); // 判断文件是否已经被编码处理 
             $contents = php_strip_whitespace($filename);  
     
             $encode =  phpCodeEncode::encode2($contents); //加密函数
            
             return file_put_contents($toFilename, $encode); 
         } 
         return false; 
    }  
     
     
    /**
     *   获取文件夹下的文件
     * 
     */
    public function getFolderFiles($file_dir = ""){
        static $file_list = array();
         
        if(empty($file_dir)){
             $dir = self::$source_php_folder;
        }else{
            $dir = $file_dir;
        }
         
         $list = scandir($dir); // 得到该文件下的所有文件和文件夹
        
        foreach($list as $file){ //遍历,如果不是PHP文件,忽略
            $file_location = $dir."/".$file;//生成路径 
        
            $type = strtolower(substr(strrchr($file_location,"."),1));
             
            if(is_dir($file_location) && $file!="." &&$file!=".."){ //判断是不是文件夹
                 
                $this->getFolderFiles($file_location); //继续遍历  
            }
             
            if(is_file($file_location)){
              $file_list[] = $file_location;
            }
         
        }
         
       return $file_list;
     
    }
 
} ?>

声明

源码下载不顺利,比如源码在百度网盘的有时会被无故取消等,请联系QQ:46667551
本站大部分下载资源收集于网络,但除特别说明之外,基本全部亲自测试可用!
但由于某些源码的更新迭代,比如微信小程序官方接口的变动等原因,
如时间过长,可能会造成本可以使用的代码出现问题,下载前请斟酌!
本站资源仅供学习和交流使用,版权归原作者所有,请在下载后24小时之内自觉删除。
若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。

原文链接:https://www.dnwfb.com//1539.html,转载请注明出处