| <?php |
| namespace app\common\model; |
|
|
| use app\common\util\Ftp as ftpOper; |
|
|
| class Upload extends Base { |
|
|
| public function api($file_path,$config) |
| { |
| if(empty($config)){ |
| return $file_path; |
| } |
|
|
| if ($config['mode'] == '2') { |
| $config['mode'] = 'upyun'; |
| } |
| elseif ($config['mode'] == '3'){ |
| $config['mode'] = 'qiniu'; |
| } |
| elseif ($config['mode'] == '4') { |
| $config['mode'] = 'ftp'; |
| } |
| elseif ($config['mode'] == '5') { |
| $config['mode'] = 'weibo'; |
| } |
|
|
| if(!in_array($config['mode'],['local','remote'])){ |
| $cp = 'app\\common\\extend\\upload\\' . ucfirst($config['mode']); |
| if (class_exists($cp)) { |
| $c = new $cp($config); |
| $file_path = $c->submit($file_path); |
| } |
| } |
|
|
| return str_replace(['http:','https:'],'mac:',$file_path); |
| } |
|
|
| public function upload($p=[]) |
| { |
| $param = input(); |
| if(!empty($p)){ |
| $param = array_merge($param,$p); |
| } |
|
|
| $param['from'] = empty($param['from']) ? '' : $param['from']; |
| $param['input'] = empty($param['input']) ? 'file' : $param['input']; |
| $param['flag'] = empty($param['flag']) ? 'vod' : $param['flag']; |
| $param['thumb'] = empty($param['thumb']) ? '0' : $param['thumb']; |
| $param['thumb_class'] = empty($param['thumb_class']) ? '' : $param['thumb_class']; |
| $param['user_id'] = empty($param['user_id']) ? '0' : $param['user_id']; |
| $base64_img = $param['imgdata']; |
| $data = []; |
| $config = (array)config('maccms.site'); |
| $pre= $config['install_dir']; |
| $upload_image_ext = 'jpg,jpeg,png,gif,webp'; |
| $upload_file_ext = 'doc,docx,xls,xlsx,ppt,pptx,pdf,wps,txt,rar,zip,torrent'; |
| $upload_media_ext = 'rm,rmvb,avi,mkv,mp4,mp3'; |
| $add_rnd = false; |
| $config = (array)config('maccms.upload'); |
|
|
| if(!empty($param['from'])){ |
| $cp = 'app\\common\\extend\\editor\\' . ucfirst($param['from']); |
| if (class_exists($cp)) { |
| $c = new $cp; |
| $c->front($param); |
| } |
| else{ |
| return self::upload_return(lang('admin/upload/not_find_extend'), ''); |
| } |
| } |
| else{ |
| $pre=''; |
| } |
|
|
| |
| $_upload_path = ROOT_PATH . 'upload' . '/' . $param['flag'] . '/' ; |
| |
| $_save_path = 'upload'. '/' . $param['flag'] . '/'; |
| if($param['flag']=='user'){ |
| $uniq = $param['user_id'] % 10; |
| $_upload_path .= $uniq .'/'; |
| $_save_path .= $uniq .'/'; |
| $_save_name = $param['user_id'] . '.jpg'; |
|
|
| if(!file_exists($_save_path)){ |
| mac_mkdirss($_save_path); |
| } |
| } |
| else{ |
| $ymd = date('Ymd'); |
| $n_dir = $ymd; |
| for($i=1;$i<=100;$i++){ |
| $n_dir = $ymd .'-'.$i; |
| $path1 = $_upload_path . $n_dir. '/'; |
| if(file_exists($path1)){ |
| $farr = glob($path1.'*.*'); |
| if($farr){ |
| $fcount = count($farr); |
| if($fcount>999){ |
| continue; |
| } |
| else{ |
| break; |
| } |
| } |
| else{ |
| break; |
| } |
| } |
| else{ |
| break; |
| } |
| } |
| $_save_name = $n_dir . '/' . md5(microtime(true)); |
| } |
|
|
|
|
| if(!empty($base64_img)){ |
| if(preg_match('/^(data:\s*image\/(\w+);base64,)/', $base64_img, $result)){ |
| $type = $result[2]; |
| if(in_array($type, explode(',', $upload_image_ext))){ |
| if(!file_put_contents($_save_path.$_save_name, base64_decode(str_replace($result[1], '', $base64_img)))){ |
| return self::upload_return(lang('admin/upload/upload_faild'), $param['from']); |
| } |
| $file_size = round(filesize('./'.$_save_path.$_save_name)/1024, 2); |
| } |
| else { |
| return self::upload_return(lang('admin/upload/forbidden_ext'), $param['from']); |
| } |
| } |
| else{ |
| return self::upload_return(lang('admin/upload/no_input_file'), $param['from']); |
| } |
| } |
| else { |
| $file = request()->file($param['input']); |
| if (empty($file)) { |
| return self::upload_return(lang('admin/upload/no_input_file'), $param['from']); |
| } |
| if ($file->getMime() == 'text/x-php') { |
| return self::upload_return(lang('admin/upload/forbidden_ext'), $param['from']); |
| } |
|
|
| if ($file->checkExt($upload_image_ext)) { |
| $type = 'image'; |
| } elseif ($file->checkExt($upload_file_ext)) { |
| $type = 'file'; |
| } elseif ($file->checkExt($upload_media_ext)) { |
| $type = 'media'; |
| } else { |
| return self::upload_return(lang('admin/upload/forbidden_ext'), $param['from']); |
| } |
| $upfile = $file->move($_upload_path,$_save_name); |
| if (!is_file($_upload_path.$upfile->getSaveName())) { |
| return self::upload_return(lang('admin/upload/upload_faild'), $param['from']); |
| } |
| $file_size = round($upfile->getInfo('size')/1024, 2); |
| $_save_name = str_replace('\\', '/', $upfile->getSaveName()); |
| } |
|
|
|
|
| $resource = fopen($_save_path.$_save_name, 'rb'); |
| $fileSize = filesize($_save_path.$_save_name); |
| 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); |
| if(preg_match("/(3c25.*?28.*?29.*?253e)|(3c3f.*?28.*?29.*?3f3e)|(3C534352495054)|(2F5343524950543E)|(3C736372697074)|(2F7363726970743E)/is", $hexCode)){ |
| return self::upload_return(lang('admin/upload/upload_safe'), $param['from']); |
| } |
|
|
| $file_count = 1; |
| $data = [ |
| 'file' => $_save_path.$_save_name, |
| 'type' => $type, |
| 'size' => $file_size, |
| 'flag' => $param['flag'], |
| 'ctime' => request()->time(), |
| 'thumb_class'=>$param['thumb_class'], |
| ]; |
|
|
| $data['thumb'] = []; |
| if($param['flag']=='user'){ |
| $add_rnd=true; |
| $file = $_save_path.str_replace('\\', '/', $_save_name); |
| $new_thumb = $param['user_id'] .'.jpg'; |
| $new_file = $_save_path . $new_thumb; |
| try { |
| $image = \think\Image::open('./' . $file); |
| $t_size = explode('x', strtolower($GLOBALS['config']['user']['portrait_size'])); |
| if (!isset($t_size[1])) { |
| $t_size[1] = $t_size[0]; |
| } |
| $image->thumb($t_size[0], $t_size[1], 6)->save('./' . $new_file); |
| $file_size = round(filesize('./' .$new_file)/1024, 2); |
| } |
| catch(\Exception $e){ |
| return self::upload_return(lang('admin/upload/make_thumb_faild'), $param['from']); |
| } |
| $update = []; |
| $update['user_portrait'] = $new_file; |
| $where = []; |
| $where['user_id'] = $GLOBALS['user']['user_id']; |
| $res = model('User')->where($where)->update($update); |
| if ($res === false) { |
| return self::upload_return(lang('index/portrait_err'), $param['from']); |
| } |
| } |
| else { |
| if ($type == 'image') { |
| if ($config['watermark'] == 1) { |
| model('Image')->watermark($data['file'], $config, $param['flag']); |
| } |
| if ($param['thumb'] == 1 && $config['thumb'] == 1) { |
| $dd = model('Image')->makethumb($data['file'], $config, $param['flag']); |
| if (is_array($dd)) { |
| $data = array_merge($data, $dd); |
| } |
| } |
| } |
| } |
| unset($upfile); |
|
|
| if ($config['mode'] == 2) { |
| $config['mode'] = 'upyun'; |
| } |
| elseif ($config['mode'] == 3){ |
| $config['mode'] = 'qiniu'; |
| } |
| elseif ($config['mode'] == 4) { |
| $config['mode'] = 'ftp'; |
| } |
| elseif ($config['mode'] == 5) { |
| $config['mode'] = 'weibo'; |
| } |
|
|
| $config['mode'] = strtolower($config['mode']); |
|
|
| if(!in_array($config['mode'],['local','remote'])){ |
| $data['file'] = model('Upload')->api($data['file'],$config); |
| if(!empty($data['thumb'])){ |
| $data['thumb'][0]['file'] = model('Upload')->api($data['thumb'][0]['file'],$config); |
| } |
| } |
| if(!empty($param['from'])){ |
| if(substr($data['file'],0,4)!='http' && substr($data['file'],0,4)!='mac:'){ |
| $data['file'] = $pre. $data['file']; |
| } |
| else{ |
| $data['file'] = mac_url_content_img($data['file']); |
| } |
| } |
|
|
| $tmp = $data['file']; |
| if((substr($tmp,0,7) == "/upload")){ |
| $tmp = substr($tmp,1); |
| } |
| if((substr($tmp,0,6) == "upload")){ |
| $annex = []; |
| $annex['annex_file'] = $tmp; |
| $r = model('Annex')->infoData($annex); |
| if($r['code']!==1){ |
| $annex['annex_type'] = $type; |
| $annex['annex_size'] = $file_size; |
| model('Annex')->saveData($annex); |
| $tmp = $data['thumb'][0]['file']; |
| if(!empty($tmp)){ |
| $file_size = filesize($tmp); |
| $annex = []; |
| $annex['annex_file'] = $tmp; |
| $r = model('Annex')->infoData($annex); |
| if($r['code']!==1){ |
| $annex['annex_type'] = $type; |
| $annex['annex_size'] = $file_size; |
| model('Annex')->saveData($annex); |
| } |
| } |
| } |
| } |
| return self::upload_return(lang('admin/upload/upload_success'), $param['from'], 1, $data); |
| } |
|
|
|
|
| private function upload_return($info='',$from='',$status=0,$data=[]) |
| { |
| $arr = []; |
| if(!empty($from)){ |
| $cp = 'app\\common\\extend\\editor\\' . ucfirst($from); |
| if (class_exists($cp)) { |
| $c = new $cp; |
| $arr = $c->back($info,$status,$data); |
| } |
| } |
| elseif(ENTRANCE=='index'){ |
| $arr['msg'] = $info; |
| $arr['code'] = $status; |
| $arr['file'] = MAC_PATH . $data['file'] . '?'. mt_rand(1000, 9999); |
| } |
| else{ |
| $arr['msg'] = $info; |
| $arr['code'] = $status; |
| $arr['data'] = $data; |
| } |
| return $arr; |
| } |
|
|
| } |