laravel 实现阿里云oss文件上传功能的示例
发布:smiling 来源: PHP粉丝网 添加日期:2022-05-16 09:08:01 浏览: 评论:0
这篇文章主要介绍了laravel 实现阿里云oss文件上传功能,本文通过示例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下。
1、定义路由
- // 阿里云文件储存
- Route::group(['prefix'=>'aliyun'], function(){
- Route::get('sign', 'AliyunController@sign');
- });
2、编写 controller 层
- /**
- * 返回OSS的签名验证
- * @return JSON 签名信息
- */
- public function sign(Request $request)
- {
- //初始化一下必要的请求数据
- $id = 'xxx'; //AccessKeyId
- $key = 'xxx'; //AccessKeySecret
- $host = '//xxx.oss-cn-shenzhen.aliyuncs.com'; //OSS库地址
- $cdn_host = "//img.xxx.com"; //真实的访问地址
- $dir = 'test/'; //上传目录设置
- $callbackUrl = url('upload/callback'); //上传回调的地址
- //上传回调的参数,callbackUrl地址,callbackBody回调接收的参数,callbackBodyType通过POST调用的回调函数,所以要设置这个头
- $callback_param = array(
- 'callbackUrl' => $callbackUrl,
- 'callbackBody' => 'filename=${object}&size=${size}&mimeType =${mimeType}&height=${imageInfo.height}&width=${imageInfo.width}',
- 'callbackBodyType' => "application/x-www-form-urlencoded"
- );
- $callback_string = json_encode($callback_param); //转换成json格式
- $base64_callback_body = base64_encode($callback_string); //要返回的回调函数参数信息
- //设置过期时间
- $now = time();
- $expire = 60 * 60 * 2; //设置该policy超时时间是 2小时. 即这个policy过了这个有效时间,将不能访问,这里可以根据自己的token过期时间来设置
- $end = $now + $expire;
- $expiration = $this->gmt_iso8601($end); //进行时间格式的转换
- //处理上传限制条件
- //最大文件大小.用户可以自己设置
- $condition = array(0 => 'content-length-range', 1 => 0, 2 => 1048576000);
- $conditions[] = $condition; //设定文件大小
- //表示用户上传的数据,必须是以$dir开始, 不然上传会失败,这一步不是必须项,只是为了安全起见,防止用户通过policy上传到别人的目录
- $start = array(0 => 'starts-with', 1 => '$key', 2 => $dir);
- $conditions[] = $start; //必须以设定的目录开头,防止上传错误
- $arr = array('expiration' => $expiration, 'conditions' => $conditions);
- $policy = json_encode($arr);
- $base64_policy = base64_encode($policy); //要返回的上传限制参数
- //签名信息
- $string_to_sign = $base64_policy;
- $signature = base64_encode(hash_hmac('sha1', $string_to_sign, $key, true)); //要返回的签名信息
- //设置返回信息
- $response = array(
- 'accessid' => $id, //accessid
- 'host' => $host, //上传地址
- 'cdn_host' => $cdn_host, //真实的访问地址
- 'policy' => $base64_policy, //上传文件限制
- 'signature' => $signature, //签名信息
- 'expire' => $end, //失效时间
- 'callback' => $base64_callback_body, //上传回调参数
- 'dir' => $dir //上传的目录
- );
- return response()->json([
- 'code' => 0,
- 'msg' => 'success',
- 'data' => $response
- ]);
- }
- //格式化时间,格式为2020-07-07T23:48:43Z
- public function gmt_iso8601($time)
- {
- $dtStr = date("c", $time);
- $pos = strpos($dtStr, '+');
- $expiration = substr($dtStr, 0, $pos);
- return $expiration . "Z";
- }
3、查看接口返回
4、前端界面及操作编写,这里采用的是 vue
- <template>
- <div class="test" style="padding:100px 0px 1000px 0px;">
- <div>
- <input type="file" id="file" name="file" />
- <a @click="upload()" href="javascript:;" rel="external nofollow" >上传</a>
- </div>
- </div>
- </template>
- <script>
- export default {
- data(){
- return {
- }
- },
- mounted() {
- this.getOssToken();
- },
- methods: {
- //获取上传通行证
- getOssToken(){
- var _self = this;
- this.axios.get('/aliyun/sign').then((res)=>{
- var data = res.data;
- if(data.code==0){
- _self.aliyunOssToken = data.data;
- }else{
- _self.$message.warning(data.msg);
- }
- });
- },
- upload(){
- var _self = this;
- var getSuffix = function (fileName) {
- var pos = fileName.lastIndexOf(".");
- var suffix = '';
- if (pos != -1) {
- suffix = fileName.substring(pos);
- }
- return suffix;
- }
- var file = $("#file").val();
- if (file.length == 0) {
- alert("请选择文件");
- }
- var oFileName = file.lastIndexOf('\\');
- var oFileName = file.substr(oFileName+1);
- var fileName = oFileName.lastIndexOf('.');
- var fileName = oFileName.substr(0,fileName);
- console.log(fileName);
- var filename = new Date().getTime() + getSuffix(file);
- var formData = new FormData();
- //注意formData里append添加的键的大小写
- formData.append('key', _self.aliyunOssToken.dir + filename); //存储在oss的文件路径
- formData.append('OSSAccessKeyId', _self.aliyunOssToken.accessid); //accessKeyId
- formData.append('policy', _self.aliyunOssToken.policy); //policy
- formData.append('Signature', _self.aliyunOssToken.signature); //签名
- formData.append("file", $("#file")[0].files[0]);
- formData.append('success_action_status', 200); //成功后返回的操作码
- var url = _self.aliyunOssToken.host;
- var fileUrl = _self.aliyunOssToken.cdn_host +'/'+ _self.aliyunOssToken.dir + filename;
- $.ajax({
- url: url,
- type: 'POST',
- data: formData,
- // async: false,
- cache: false,
- contentType: false,
- processData: false,
- success: function (data) {
- console.log(fileUrl);
- console.log(data);
- },
- error: function (data) {
- console.log(data);
- }
- });
- }
- }
- }
- </script>
5、点击上传按钮,浏览器控制台输出链接,访问该链接,即可看到该图片
Tags: laravel文件上传 阿里云oss
- 上一篇:Laravel框架实现点播上传阿里云功能
- 下一篇:最后一页
相关文章
- ·Laravel框架文件上传功能实现方法示例(2021-11-18)
- ·Laravel框架实现文件上传的方法分析(2021-12-24)
- ·Laravel中使用阿里云OSS Composer包分享(2021-05-11)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)