中文字幕在线观看,亚洲а∨天堂久久精品9966,亚洲成a人片在线观看你懂的,亚洲av成人片无码网站,亚洲国产精品无码久久久五月天

php檢測(cè)圖片木馬

2018-07-20    來(lái)源:open-open

容器云強(qiáng)勢(shì)上線!快速搭建集群,上萬(wàn)Linux鏡像隨意使用
實(shí)踐php檢測(cè)圖片木馬
    <?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' => '沒(méi)有錯(cuò)誤發(fā)生,文件上傳成功。',  
                '1' => '上傳的文件超過(guò)了 php.ini 中 upload_max_filesize 選項(xiàng)限制的值。',  
                '2' => '上傳文件的大小超過(guò)了 HTML 表單中 MAX_FILE_SIZE 選項(xiàng)指定的值。',  
                '3' => '文件只有部分被上傳。',  
                '4' => '沒(méi)有文件上傳。',  
                '5' => '未能通過(guò)安全檢查的文件。',  
                '6' => '找不到臨時(shí)文件夾。',  
                '7' => '文件寫(xiě)入失敗。',  
                '8' => '文件類型不支持',  
                '9' => '上傳的臨時(shí)文件丟失。',  
          );  
       
          //@ 開(kāi)始執(zhí)行文件上傳  
          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]);  
               }  
    }  
       
        //@ 私有 上傳開(kāi)始  
        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進(jìn)制檢測(cè) 黑客  
        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進(jìn)制中的 */  
                /* 匹配16進(jìn)制中的 */  
                /* 匹配16進(jìn)制中的  

標(biāo)簽: 安全

版權(quán)申明:本站文章部分自網(wǎng)絡(luò),如有侵權(quán),請(qǐng)聯(lián)系:west999com@outlook.com
特別注意:本站所有轉(zhuǎn)載文章言論不代表本站觀點(diǎn)!
本站所提供的圖片等素材,版權(quán)歸原作者所有,如需使用,請(qǐng)與原作者聯(lián)系。

上一篇: jQuery序列化表單為JSON對(duì)象

下一篇: json封裝與解析的Java工具類