加入收藏 | 设为首页 | 会员中心 | 我要投稿 安卓应用网 (https://www.0791zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > PHP > 正文

php检测图片木马

发布时间:2020-05-25 07:44:53 所属栏目:PHP 来源:互联网
导读:php检测图片木马

下面是脚本之家 jb51.cc 通过网络收集整理的代码片段。

脚本之家小编现在分享给大家,也给大家做个参考。

实践php检测图片木马
    <?php   
    /** 
      +------------------------------------------------------------------------------ 
    * Upload 文件上传类 
      +------------------------------------------------------------------------------ 
    * @package   Upload 
    * @author    nicegy  
    * @version   $Id: Upload.class.php 2014-4-11 19:00:23 nicegy $ 
      +------------------------------------------------------------------------------ 
    */  
    class Upload {  
       
          private static $image = null;  
          private static $status = 0;  
          private static $suffix = null;  
          private static $imageType = array('.jpg','.bmp','.gif','.png');  
          private static $message = array(  
                '0' => '没有错误发生,文件上传成功。','1' => '上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值。','2' => '上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。','3' => '文件只有部分被上传。','4' => '没有文件上传。','5' => '未能通过安全检查的文件。','6' => '找不到临时文件夹。','7' => '文件写入失败。','8' => '文件类型不支持','9' => '上传的临时文件丢失。',);  
       
          //@ 开始执行文件上传  
          public static function start($feild = 'file') {  
                if (!empty($_FILES)) {  
                    self::$status = $_FILES[$feild]['error'];  
                   if (self::$status > 0)  
                          return array('status' => self::$status,'msg' => self::$message[self::$status]);  
                      self::$image = $_FILES[$feild]['tmp_name'];  
                      self::$suffix = strtolower(strrchr($_FILES[$feild]['name'],'.'));  
                      return array('status' => self::_upload(),'path' => self::$image,'msg' => self::$message[self::$status]);  
               } else {  
                      return array('status' => self::$status,'msg' => self::$message[self::$status]);  
               }  
    }  
       
        //@ 私有 上传开始  
        private static function _upload($path = './upload/') {  
            date_default_timezone_set('PRC');  
            $newFile = $path . date('Y/m/d/His') . rand(100,999) . self::$suffix;  
            self::umkdir(dirname($newFile));  
            if (is_uploaded_file(self::$image) && move_uploaded_file(self::$image,$newFile)) {  
                self::$image = $newFile;  
                if (in_array(self::$suffix,self::$imageType))  
                    return self::checkHex();  
                else  
                    return self::$status = 0;  
            } else {  
                return self::$status = 9;  
            }  
        }  
       
        //@ 私有 16进制检测 黑客  
        private static function checkHex() {  
            if (file_exists(self::$image)) {  
                $resource = fopen(self::$image,'rb');  
                $fileSize = filesize(self::$image);  
                fseek($resource,0);  
                if ($fileSize > 512) { // 取头和尾  
                    $hexCode = bin2hex(fread($resource,512));  
                    fseek($resource,$fileSize - 512);  
                    $hexCode .= bin2hex(fread($resource,512));  
                } else { // 取全部  
                    $hexCode = bin2hex(fread($resource,$fileSize));  
                }  
                fclose($resource);  
                /* 匹配16进制中的 */  
                /* 匹配16进制中的 */  
                /* 匹配16进制中的  

以上是脚本之家(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。

如果觉得脚本之家网站内容还不错,欢迎将脚本之家网站推荐给程序员好友。

(编辑:安卓应用网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读