laravel 实现阿里云oss文件上传功能的示例

admin3年前PHP教程25

1、定义路由

?

1
2
3
4
// 阿里云文件储存
Route::group(['prefix'=>'aliyun'], function(){
    Route::get('sign', 'AliyunController@sign');
});






2、编写 controller 层

?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
/**
     * 返回OSS的签名验证
     * @return JSON 签名信息
     */
    public function sign(Request $request)
    {
        //初始化一下必要的请求数据
        $id = 'xxx';   //AccessKeyId
        $key = 'xxx'//AccessKeySecret
        $host = '//xxx.oss-cn-shenzhen.aliyuncs';  //OSS库地址
        $cdn_host = "//img.xxx"; //真实的访问地址
        $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

?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
<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、点击上传按钮,浏览器控制台输出链接,访问该链接,即可看到该图片

到此这篇关于laravel 实现阿里云oss文件上传功能的示例的文章就介绍到这了,更多相关laravel 阿里云oss文件上传内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:cnblogs/zion0707/p/12118661

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

PHP基础用法讲解及phpinfo();演示

在这个abc.php文件中写入如下代码。?12345<?php phpinfo(); ?>你将会看到一个网页,网页内容通常,如下图所示:用中文翻译这句话给你听?1234...

PHP的bz2压缩扩展工具详解

在日常的开发和电脑使用中,我们经常会接触到压缩和解压的一些工具,PHP 也为我们准备了很多相关的操作扩展包,都有直接可用的函数能够方便的操作一些压缩解压功能。安装扩展这个扩展的安装需要系统有 bzip...

如何使用Laravel Eloquent来开发无限极分类

概述我们会创建一个微型项目来展示儿童商店的分类,总共有 5 级,如下:数据库迁移简单的数据表结构:只有一个 name 字段, 关联到其自身。所以,大部分父级分类 category_id = null,...

台湾大带宽服务器可靠吗主要看哪些

台湾大带宽服务器可靠吗主要看哪些?要评估台湾大带宽服务器的可靠性,需要考虑以下几个因素:服务器硬件质量:服务器硬件质量是服务器性能和稳定性的基础,硬件质量好的服务器通常更可靠。带宽提供商:带宽提供商的...

php遍历对象的方法

对于php来说,foreach是非常方便好用的一个语法,几乎对于每一个PHPer它都是日常接触最多的请求之一。那么对象是否能通过foreach来遍历呢?答案是肯定的,但是有个条件,那就是对象的遍历只能...

高防服务器配置指标有什么方面?怎么衡量好坏?国内电信高防服务器性能如何?

谈到产品配置,不少人已早有耳闻,像大家平常购买手机、电脑等电子类产品时,都会关注到这个产品的配置如何,使用的时候流不流畅,会不会出现延迟大顿等。同样的,在大家购买高防服务器的时候,依旧会参考这些指标来...