最近使用vue比较多,项目过程中遇到了,上传图片、视频到阿里云的OSS存储服务,发现目前现成的上传组件,都不太支持,于是自己各种查看阿里云的文档及google,百度,自己写了一套符合自己的业务的上传组件,想到其他小伙伴肯定也会遇到类似的问题,就花了些时间,把组件提取出来,上传到了npm。

基本思路:

服务端提供接口,获取阿里云STS临时访问OSS的权限,初始化ossClient,调用oss的sdk进行上传。通过vue2.3重新引入的sync特性返回上传结果

使用组件时,需要导入Css样式。自己不擅长写样式,写的比较挫,希望可以被改进,哈哈

  • TODO: 上传的进度,等尚未实现,只有最终上传结果

Vue 2.3.0+

NPM

vue-oss-upload

Note

需要依赖阿里云的oss的SDK,可以在index.html中引入

<script type="text/javascript" src="https://gosspublic.alicdn.com/aliyun-oss-sdk.min.js"></script>

组件依赖vue2.3以上的版本

vue2.3 重新引入了 .sync 修饰符,但是这次它只是作为一个编译时的语法糖存在。它会被扩展为一个自动更新父组件属性的 v-on 侦听器。

.sync 修饰符

Use Setup

Install vue-oss-upload

1
npm install vue-oss-upload --save

props

 props: {
      // 需要引入阿里云OSS的SDK,并初始化ossClient
      ossClient: {
        type: Object,
        toWay: false
      },
      // 是非支持多文件上传
      multiple: {
        type: Boolean,
        twoWay: false
      },
      // 上传组件id,区别页面中多次使用上传组件
      id: {
        type: String,
        twoWay: false
      },
      // 上传成功后的uri
      url: {
        type: String,
        twoWay: true
      },
       // 上传结果
      uploadRes: {
        type: Boolean,
        twoWay: true
      },
      // 上传按钮的名称
      inputName: {
        type: String,
      },
      // 上传文件的名称
      uploadFileName: {
        type: String,
      },
      // 上传到OSS的路径
      path: {
        type: String,
      },
    },

Example

<template>
    <div>
        <upload-ali-oss :url.sync="uploadForm.content.path" :multiple="true"
                        :id="uploadForm.id"
                        :ossClient="this.ossClient"
                        :inputName="uploadForm.inputName"
                        :uploadFileName="uploadForm.uploadFileName"
                        :path="uploadForm.upload.path"
                        :uploadRes.sync="uploadForm.uploadRes"
        ></upload-ali-oss>
        <div v-show="uploadForm.uploadRes"
             v-text="uploadForm.content.path">
        </div>
        <div>
            <img v-if="uploadForm.uploadRes"
                 :src="this.imgSrc">
        </div>
    </div>
</template>

<script>
    import VueUploadAliOSS from 'vue-oss-upload';
    import Css from 'vue-oss-upload/dist/vue-alioss-upload.min.css'
    export default {
        name: 'app',
        components: {
            'upload-ali-oss': VueUploadAliOSS
        },
        data() {
            return {
                ossClient: Object,
                uploadForm: {
                    id: 'imgFile',
                    inputName: '上传图片',// 自定义
                    uploadFileName: '2017063010192023',// 上传文件的名称
                    content: {
                        path: '',
                    },
                    upload: {
                        path: 'img/test/',// 自定义路径
                    },
                    uploadRes: false,
                },
                imgSrc: ''
            }
        },
        methods: {
            // 需要引入阿里云的ossSDK
            //初始化OSS 权限, 建议后台提供获取oss临时权限的接口
            initOSSAuth() {

                let Oss = OSS.Wrapper;
                this.ossClient = new Oss({
                    region: '',
                    accessKeyId: '',
                    accessKeySecret: '',
                    stsToken: '',
                    bucket: '',
                    endpoint: '',
                });
            },
            // 展示上传的内容(图片)
            showUploadContent() {
                if (this.uploadForm.content.path) {

                    let path = this.uploadForm.content.path;

                    var result = this.ossClient.signatureUrl(path, {
                        response: {
                            // 'content-disposition': 'attachment; filename="' + filename + '"'
                            'Content-Type': 'image/jpeg'
                        }
                    });
                    this.imgSrc = result;
                }
            }
        },
        watch: {
            'uploadForm.content.path' (val, oldVal) {
//                console.log('new: %s, old: %s', val, oldVal)
                if ('' !== val) {
                    this.showUploadContent();
                }
            }
        },
        mounted() {
            this.initOSSAuth();
        }
    }
</script>
<style>
</style>

展示效果

Author Blog

kai.fantasy