首页 > php教程 > PHP源码 > 正文

php检测图片木马

大家讲道理
发布: 2016-11-09 14:31:49
原创
2458人浏览过

<?php   

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进制中的
登录后复制

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号