基于thinkphp5.0.15, 可以扩展数据库保存
自己了个七牛云调用类,用的是官方SDK 7.2.3 直接将文件放到Qinui里
将整个Qinui文件夹放到 extend 即可。
'.gif|.jpeg|.png|.bmp|.jpg',//图片类型
'size' => 2*1024*1024//文件大小 2M
);
public function __construct($prefix=null)
{ $this->accessKey = Config::get('appkey.qnyaccessKey'); $this->secretKey = Config::get('appkey.qnysecretKey'); $this->bucket = Config::get('appkey.qnybucket'); $this->url = Config::get('appkey.qnyurl'); if($prefix){
(substr($prefix,-1) == '/')? $prefix : $prefix.'/';
}
} public function __get($name)
{ return $this->$name;
}
public function __destruct()
{ //trace('bb','aaa');
}
public function fetchImg($url,$suffix='jpg')
{
$auth = new Auth($this->accessKey, $this->secretKey);
$bucketManager = new BucketManager($auth);
$key=date('YmdHis').rand(10000, 99999).'.'.$suffix; list($ret, $err) = $bucketManager->fetch($url, $this->bucket, $key); if ($err == null) { $this->saveToDB($ret['key']); return $this->url.$ret['key'];
}
}
public function authUploadToken()
{ //设置了回调地址,前端就不会返回值了。
$expires=array( 'returnBody'=>'{"key":"'.$this->url.'$(key)","hash":"$(etag)","fsize":$(fsize),"name":"$(x:name)"}', 'callbackUrl' => 'https://www.wyx2013.cn/wxapi/qiniucallback', 'callbackBody' => '{"key":"$(key)","hash":"$(etag)","fsize":$(fsize),"bucket":"$(bucket)","name":"$(x:name)","user":"admin"}', 'callbackBodyType' => 'application/json'
);
$auth = new Auth($this->accessKey, $this->secretKey); return $auth->uploadToken($this->bucket, null,600, $expires);//前端上传,第三个参数为时间,不用太长
}
public function uploadimg($file)
{
$suffix=$this->checkimgfile($file['name'],$file['size']); if($suffix){
$img=$this->uploadFile($file['tmp_name'],$suffix);
$imgurl=$this->url.$img; $this->imgUrlArray[]=$img; return $imgurl;//返回的是一张图片的地址
}
}
public function uploadimgs($file='files')
{
$c=count($_FILES[$file]['error']); for($i=0;$i<$c;++$i){
$suffix=$this->checkimgfile($_FILES[$file]['name'][$i],$_FILES[$file]['size'][$i]); if($suffix){
$img=$this->uploadFile($_FILES[$file]['tmp_name'][$i],$suffix); if($img){
$imgurlarray[]=$this->url.$img;
}
}
} $this->saveToDB($imgurlarray); return $imgurlarray;//调用此方法,返回的是数组
}
public function delete($key='')
{
$auth = new Auth($this->accessKey, $this->secretKey);// 构建鉴权对象
$bucketMgr = new BucketManager($auth);//初始化BucketManager
$err = $bucketMgr->delete($this->bucket, $key); return $err ? true : false ;
}
public function listFiles($c = false )
{
$auth = new Auth($this->accessKey, $this->secretKey);// 构建鉴权对象
$bucketMgr = new BucketManager($auth);
$bucket=$this->bucket;
$prefix = 'image/jpg/';//前缀
$marker = '';//标记
$limit = 10000;//条数
$delimiter = '/';//指定目录分隔符
list($iterms, $err) = $bucketMgr->listFiles($bucket, $prefix, $marker, $limit, $delimiter); if ($err !== null) { return false;//没有文件返回空
} else { if($c){ return $iterms; }else{ return count($iterms); }
}
}
public function checkimgfile($name,$size)
{
$suffix=pathinfo($name, PATHINFO_EXTENSION); //取得后缀
if(stripos(self::$imgconfig['types'],$suffix) && $sizeaccessKey, $this->secretKey);// 构建鉴权对象
$bucket = $this->bucket;// 要上传的空间
$token = $auth->uploadToken($bucket);// 生成上传 Token
$uploadMgr = new UploadManager();// 构建 UploadManager 对象
$key=date('YmdHis').rand(10000, 99999) . '.' . $suffix;//文件名 用时间命名
$key=empty($this->prefix) ? $key : $this->prefix.$key; list($ret, $err) = $uploadMgr->putFile($token, $key, $fileOjb);//上传
return ($err !== null)? false : $ret['key'];
}
private function saveToDB($img )
{ //$m=new AdminImg();
if(is_string($img)){ //$m->img=$img;
//$m->imgurl=$imgurl;
//$m->save();
}elseif(is_array($img)){
$url=$this->url; foreach($img as $value){
$data[]=array('img'=>$value,'imgurl'=>$url.$value);
} //$m->saveAll($data);
}
}
} 这里只封装了部分功能
上传文件返回值为[{"suc":"http:// xample.com/2018033122531446150.png"},{"suc":"xxxx"}]
public function ajaxuploadimgs()
{ if ( !empty($_FILES) ) {
$q = new Qnycn(); foreach ($_FILES as $key=>$file){ if ($file['error'] !== 0) { continue;
} else {
$imgurl = $q->uploadimg($file,$key); if($imgurl){
$c[] = array('suc'=>$imgurl);
}else{
$c = array('err'=>'七牛云上传失败');
}
}
} return json_encode($c);
} return false;
}如果是多个图片上传会产生一个问题,会调用多次类,可以将调用方也写到Qnycn的类里面。
附上jQuery上传代码。


