简介
laravel图片上传网上的代码太多了,下面贴一段我自己整理的图片上传,通过七牛云上传。
七牛上传的包为:github.com/overtrue/laravel-filesy...
强烈建议查看七牛云的官方文档:developer.qiniu.com/kodo/sdk/php
提示:不应该由后端直接上传文件,应该 后端提供token,交给前端上传!
下面是文件上传的公共方法:
if (!function_exists('base64_upload')) { | |
/** | |
* base64 文件上传,文件路径需要自己指定,但是文件会按照月份存放在文件夹中 | |
* | |
* @param string $content base64内容 | |
* @param string $path 存储文件夹,例如轮播图一般存储在images/adv 里面 | |
* @param string $file_name 文件名字 | |
* @param string $disk 磁盘名称,默认使用public 磁盘,可被外界访问 | |
* @param boolean $full_path 是否显示完整路径 | |
* | |
* @return array|string 错误则返回数组,否则返回地址 | |
*/ | |
function base64_upload($content, $path = '/', $file_name = '', $disk = 'public', $full_path = false) | |
{ | |
if (preg_match('/^(data:\s*image\/(\w+);base64,)/', $content, $result)) { | |
$type = $result[2]; | |
if (!in_array($type, ["png", "jpg", "gif", 'jpeg'])) { | |
return [ | |
'result' => false, | |
'msg' => '图片格式不正确,支持png, jpg, gif, jpeg', | |
]; | |
} | |
// 添加月份文件夹 | |
if ($path === '/') $path = $path . '/' . date("Ym/d", time()) . '/'; | |
if (!$file_name) $file_name = create_guid() . '.' . $type; | |
$storage = Storage::disk($disk); | |
if ($storage->exists($path . $file_name)) { // 若存在相同的文件则删除原来的图片地址即可 | |
$storage->delete($path . $file_name); | |
} | |
// 将base64文件转换为二进制流图片、base64图片、二进制图片转换见:https://blog.csdn.net/bt_xxx/article/details/94588358 | |
$bool = $storage->put($path . $file_name, base64_decode(str_replace($result[1], '', $content))); | |
if ($bool) { | |
$real_url = $full_path ? $storage->url($path . $file_name) : $path . $file_name; | |
if (false === strpos($real_url, '?')) { | |
$real_url .= '?hash=' . create_guid(); | |
} else { | |
$real_url .= '&hash=' . create_guid(); | |
} | |
return $real_url; | |
} | |
} | |
return [ | |
'result' => false, | |
'msg' => '图片数据不是base64格式', | |
]; | |
} | |
} | |