| | <?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; |
| | } |
| |
|
| | } |