使用Element-UI框架的upload组件直传视频至七牛云(代码教程)

13 篇文章 0 订阅
4 篇文章 0 订阅

前言:七牛云是一个不错的云服务提供商,尤其是其对象存储和cdn是有一定的免费额度,对于小众开发者来说还是很划算的。为了更好的用户体验和上传速度,决定通过七牛云存储来上传视频文件。

 前情图示:

                                       图片来源:使用Element UI框架(基于vue2.0)的upload组件上传图片至七牛云

一、找到你七牛云存储的区域的客户端url

七牛云存储的区域表格(客户端)
存储区域区域简称上传域名
华东z0http(s)://upload.qiniup.com
华北z1http(s)://upload-z1.qiniup.com
华南z2http(s)://upload-z2.qiniup.com

文档参考:七牛云存储直传文件

二、 提供一个服务端接口:七牛上传token接口

笔者使用php框架Laravel来提供接口服务,由于本身就已经使用了七牛扩展包overtrue/laravel-filesystem-qiniu。大同小异,随便选择一个七牛云扩展也是可以完成此接口(基本是继承七牛云的SDK再造轮子)。

代码:

// 第一步,引入七牛Auth类
use Qiniu\Auth;
// 第二步,实例话七牛Auth类
// config是Laravel框架自带获取配置参数的函数。其他框架或者语言请自行填写
// config('filesystems.qiniu.access_key')是取配置文件中的access_key参数
// config('filesystems.qiniu.secret_key')是取配置文件中的secret_key参数
// config('filesystems.qiniu.bucket')是取配置文件中的bucket参数
$auth = new Auth(config('filesystems.qiniu.access_key'),env('filesystems.qiniu.secret_key'));
        
return response()->json([
      'token' => $auth->uploadToken(config('filesystems.qiniu.bucket'))
]);

// 这里建议如果使用cdn加速,以及其他一些参数可以在这个接口返回必须的字段。如返回 

response()->json([
      'action' => 'http://upload-z2.qiniup.com', // 七牛云存储客户端直传域名
      'cdn'    => 'https://cdn.xxxx.com', // cdn域名
      'token'  => $auth->uploadToken(config('filesystems.qiniu.bucket'))
]);

三、前端代码模块

我们应该自定义一个方法来实现。根据官方文档,要覆盖默认的行为,要绑定http-request。这里使用了el-progress来展示进度条,通过axios的onUploadProgress方法来获取实时的进度,我们直接贴上代码,具体实现的思想就在代码里了。

<template>
    <div>
        <el-form>
            <el-form-item label="添加视频:">
                <el-radio-group v-model="model.other.origin">
                    <el-radio :label="0">上传视频</el-radio>
                    <el-radio :label="1">引用视频</el-radio>
                </el-radio-group>
                <!-- 上传视频的页面模块 -->
                <el-progress v-if="model.other.origin == 0 && progressPercent != 0 && progressPercent < 100"
                             style="width: 320px;"
                             :percentage="progressPercent">
                </el-progress>
                <el-upload
                        v-if="model.other.origin == 0"
                        v-loading="loading"
                        :disabled="uploadDisabled"
                        :element-loading-text="loadingText"
                        element-loading-spinner="el-icon-loading"
                        element-loading-custom-class="loading-style"
                        :action="qiNiuAction"
                        :http-request="sliderRequest"
                        :show-file-list="false"
                        :on-success="handleVideoSuccess"
                        :on-error="handleVideoError"
                        :before-upload="beforeVideoUpload"
                        drag
                >
                    <video v-if="model.other.video_url_0 !=''"
                           :poster="这里是视频封面的url"
                           :src="model.other.video_url_0"
                           class="avatar video-avatar"
                           style="width: 320px;height:180px"
                           controls="controls">
                        您的浏览器不支持视频播放
                    </video>
                    <i class="el-icon-upload"></i>
                    <div class="el-upload__text" v-if="!uploadDisabled">将文件拖到处,或<em>点击上传</em></div>
                    <div class="el-upload__tip" v-if="!uploadDisabled" slot="tip">只能上传视频文件,且不超过200M</div>
                </el-upload>
                <el-button
                        v-if="model.other.origin == 0 && uploadDisabled && model.other.video_url_0 !=''"
                        type="warning"
                        @click="reloadUpload"
                >重新上传
                </el-button>
                <!-- 引用视频的页面模块 -->
                <el-input
                        v-if="model.other.origin == 1"
                        placeholder="请输入引用的视频url"
                        v-model="model.other.video_url_1"
                        clearable>
                </el-input>
            </el-form-item>
        </el-form>
    </div>
</template>

<script>
  import axios from 'axios'

  export default {
    data() {
      return {
        uploadDisabled: false,
        loading: false,
        qiNiuCdn: '',
        qiNiuAction: '',
        qiNiuUploadData: {
          key: '',
          token: '',
        },
        progressPercent: 0,
        loadingText: '拼命加载中',
        getQiniuTokenIng: false,
        model: {
          other: {
            origin: 0,
            video_url_0: '',
            video_url_1: ''
          }
        }
      }
    },
    methods: {
      getQiniuToken(type, name) {
        return new Promise((resolve, reject) => {
          if (!this.getQiniuTokenIng) {
            this.getQiniuTokenIng = true
            this.loading = true
            this.loadingText = 'token加载中'
            axios.get(`/qiniu/getUploadParam?type=${type}&name=${name}`).then((res) => {
              if (res.data.status == 200) {
                this.qiNiuUploadData.token = res.data.token
                this.qiNiuUploadData.key = res.data.key
                this.qiNiuCdn = res.data.cdn
                this.qiNiuAction = res.data.action
                this.getQiniuTokenIng = false
                resolve()
              } else {
                this.$message({
                  message: res.data.desc,
                  duration: 2000,
                  type: "warning"
                });
                this.getQiniuTokenIng = false
                reject()
              }
            }).catch(e => {
              reject()
            })
          }
        })
      },
      beforeVideoUpload: function (file) {
        const isLt200M = file.size / 1024 / 1024 < 200;
        if (['video/mp4', 'video/ogg', 'video/flv', 'video/avi', 'video/wmv', 'video/rmvb', 'video/mov'].indexOf(file.type) == -1) {
          this.$message.error("请上传支持的数据格式(mp4,flv,avi,wmv,rmvb,mov)");
          return false;
        }
        if (!isLt200M) {
          this.$message.error("图片大小不能超过 200MB!");
          return false;
        }
      },
      // 自定义el-upload方法
      sliderRequest(upload) {
        this.getQiniuToken(upload.file.type, upload.file.name).then((res) => {
          const formData = new FormData() // 创建FormData对象
          // 添加相关上传参数
          formData.append('file', upload.file)
          formData.append('key', this.qiNiuUploadData.key) // key 文件名处理,这样的话七牛会识别文件时什么类型
          formData.append('token', this.qiNiuUploadData.token)
          // onUploadProgress 查看axios文档 https://github.com/axios/axios
          axios.post(this.qiNiuAction, formData, {
            onUploadProgress: (event) => {
              this.loadingText = '疯狂下载中'
              this.progressPercent = parseInt(event.loaded / event.total * 100) // loaded:已上传文件大小 total:被上传文件的总大小
              // 监听上传进度
              event.percent = event.loaded / event.total * 100
              upload.onProgress(event)
            }
          }).then((response) => {
            this.loading = false
            if (response.status === 200) {
              const res = response.data
              this.handleVideoSuccess(res);
            }
          }).catch((err) => {
            this.loading = false
            this.handleVideoError();// 调用组件上传失败方法
          })
        })
      },
      handleVideoSuccess: function (res) {
        const videoUrl = this.qiNiuCdn + '/' + res.key;
        this.model.other.video_url_0 = videoUrl
        this.uploadDisabled = true
      },
      handleVideoError: function (res) {
        this.$message({
          message: "上传失败",
          duration: 2000,
          type: "warning"
        });
      },
      reloadUpload() {
        this.uploadDisabled = false
        this.model.other.video_url_0 = ''
      }
    }
  }
</script>
<style>
    .loading-style {
        width: 320px;
        height: 180px
    }

    .el-upload-dragger {
        width: 320px !important;
        height: 180px !important;
    }
</style>

有疑问就请留下你的脚步👣

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以回答你的问题。为了在ElementUI的Upload使用七牛云储存图片,你需要进行以下步骤: 1. 首先,你需要在七牛云上创建一个存储空间,并获取到你的Access Key和Secret Key。 2. 然后,在你的Vue项目中安装七牛云的SDK,可以使用npm命令进行安装: ``` npm install qiniu-js --save ``` 3. 在你的Vue组件中,你需要引入ElementUI的Upload组件,并添加一个自定义的上方法。这个方法将会在文件上时被调用: ```javascript <template> <el-upload class="upload-demo" action="/upload" :before-upload="beforeUpload" :on-success="handleSuccess" :on-error="handleError" :headers="headers" :data="data" :file-list="fileList" multiple> <el-button size="small" type="primary">点击上</el-button> </el-upload> </template> <script> import { Upload } from 'element-ui'; import Qiniu from 'qiniu-js'; export default { components: { Upload }, data() { return { fileList: [], token: '', key: '', domain: 'http://xxx.xxx.xxx.xxx/', headers: { 'Authorization': '', 'x-qiniu-url': '' }, data: { token: '', key: '' } }; }, methods: { beforeUpload(file) { // 获取上凭证 let that = this; return new Promise((resolve, reject) => { axios.get('YOUR_UPLOAD_URL') .then(response => { that.token = response.data.token; that.key = response.data.key; that.headers.Authorization = `UpToken ${that.token}`; that.headers['x-qiniu-url'] = that.domain; that.data.token = that.token; that.data.key = that.key; resolve(); }) .catch(error => { reject(error); }) }); }, handleSuccess(response, file, fileList) { // 上成功回调 console.log(response); }, handleError(error, file, fileList) { // 上失败回调 console.log(error); } } } </script> ``` 在这段代码中,我们引入了ElementUI的Upload组件和七牛云的SDK,然后在data中定义了一些变量,包括上凭证、上文件的key、七牛的域名、请求头和请求参数等。在beforeUpload方法中,我们向你的服务器请求上凭证,在请求成功后将认证信息和请求参数赋值给data和headers变量。在handleSuccess和handleError方法中,我们可以处理上成功和上失败的情况。 4. 最后,你需要在你的服务器端实现上凭证的生成。可以使用七牛云的SDK,也可以使用其他语言的SDK,例如Java或Python。在服务器端生成上凭证后,将凭证和上文件的key返回给前端。 例如,在Node.js中,你可以使用qiniu-sdk: ```javascript const qiniu = require('qiniu'); const accessKey = 'YOUR_ACCESS_KEY'; const secretKey = 'YOUR_SECRET_KEY'; const bucket = 'YOUR_BUCKET_NAME'; const mac = new qiniu.auth.digest.Mac(accessKey, secretKey); const options = { scope: bucket, expires: 7200 }; const putPolicy = new qiniu.rs.PutPolicy(options); const uploadToken = putPolicy.uploadToken(mac); app.get('/uploadToken', (req, res) => { const key = req.query.filename; res.json({ token: uploadToken, key: key }); }); ``` 在这个例子中,我们使用qiniu-sdk生成上凭证,并在/uploadToken路由中返回凭证和上文件的key。 这样,你就可以在ElementUI的Upload使用七牛云存储图片了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值