php检测图片木马

2018-07-20    来源:open-open

容器云强势上线!快速搭建集群,上万Linux镜像随意使用
实践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进制中的  

标签: 安全

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点!
本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。

上一篇: jQuery序列化表单为JSON对象

下一篇: json封装与解析的Java工具类