七牛云上传原理


1.原理图

在这里插入图片描述

2.python 获取七牛云上传token

在这里插入图片描述

# 获取七牛云上传token
class QnyView(APIView):
    def get(self,request):
        from qiniu import Auth
        # 需要填写你的 Access Key 和 Secret Key
        access_key = '6mZI4Qopv57oAV5SHAHItpPnxlW5tHXeaRsJ8Rps'
        secret_key = 'PdrUR6e_unDTo43yt8mDe9NtFSFoa8oGcI-1krs6'
        # 构建鉴权对象
        q = Auth(access_key, secret_key)
        # 要上传的空间
        bucket_name = 'syl-medias'
        # 上传后保存的文件名
        # key = ''  # 注 : 上传key的话,可能会上传失败,不上传,key可以上成功 
        # 生成上传 Token,可以指定过期时间等
        # 上传策略示例
        # https://developer.qiniu.com/kodo/manual/1206/put-policy
        policy = {
            # 'callbackUrl':'https://requestb.in/1c7q2d31',
            # 'callbackBody':'filename=$(fname)&filesize=$(fsize)'
            # 'persistentOps':'imageView2/1/w/200/h/200'
        }
        # 3600为token过期时间,秒为单位。3600等于一小时
        # token = q.upload_token(bucket_name, key, 3600, policy)
        token = q.upload_token(bucket_name,expires=3600) # 携带参数
        return Response({'code':200,'msg':'Token获取成功','uptoken':token})



2.1Vue配置

<template>
  <div>
    <!-- 1.上传时的点击框  -->
    <div id="container">
      <div>
        <div id="uploadImage">选择文件{{uptoken}}</div>
        <div class="upload-progress"></div>
      </div>
    </div>

    <!-- 2.测试上传成功后播放功能  -->
    <div v-show="true">
      <video id="video"  width="320" height="240" :src="qn_url" controls="controls" autoplay="autoplay" muted loop="loop" >
        您的浏览器不支持 video 标签。
      </video>
    </div>
  </div>
</template>

<script>
  import $ from 'jquery'   // 导入jquery
  import { qn_token_get } from './axios_api/api'  // 封装的axios 获取七牛云token


  export default {
    data() {
      return {
        uptoken: '',
        qn_url: 'http://qi69bt0m2.hn-bkt.clouddn.com/',   // 七牛云域名
      };
    },
    methods: {
      getQiniuToken: function (callback){
        qn_token_get({ }).then(resp => {
          console.log('>>>>>>>>>>>>',resp.uptoken)
          // debugger
          this.uptoken = resp.uptoken;
          callback()  // callback 出入的是回调函数 initQiniu() 用来初始化Qiniu.uploader()
        }).catch( err=>{
          console.log(err,'err')
        })
      },

      initQiniu: function () {
        var ths = this
        var uploader = Qiniu.uploader({
          disable_statistics_report: false,                                   // 禁止自动发送上传统计信息到七牛,默认允许发送
          runtimes: 'html5,flash,html4',                                      // 上传模式,依次退化
          browse_button: 'uploadImage',                                       // 上传选择的点选按钮,必需
          container: 'container',                                             // 上传区域DOM ID,默认是browser_button的父元素
          max_file_size: '500mb',                                             // 最大文件体积限制
          flash_swf_url: 'Moxie.swf',                                         // 引入flash,相对路径
          dragdrop: false,                                                    // 关闭可拖曳上传
          chunk_size: '4mb',                                                  // 分块上传时,每块的体积
          multi_selection: !(moxie.core.utils.Env.OS.toLowerCase() === "ios"),
          uptoken: this.uptoken,     // 在初始化时,uptoken,uptoken_url,uptoken_func三个参数中必须有一个被设置,uptoken是上传凭证,由其他程序生成;uptoken_url是提供了获取上传凭证的地址,如果需要定制获取uptoken的过程则可以设置uptoken_func;其优先级为uptoken > uptoken_url > uptoken_func
          // uptoken_url: 'http://127.0.0.1:8000/uptoken',                                                 // 在初始化时,uptoken,uptoken_url,uptoken_func三个参数中必须有一个被设置,uptoken是上传凭证,由其他程序生成;uptoken_url是提供了获取上传凭证的地址,如果需要定制获取uptoken的过程则可以设置uptoken_func;其优先级为uptoken > uptoken_url > uptoken_func
          // uptoken:'q06bq54Ps5JLfZyP8Ax-qvByMBdu8AoIVJpMco2m:kyTiuN6GBUpfNt1nJIA7C8CCStY=:eyJzY29wZSI6IjEzMTIzMTIzMTIzIiwiZGVhZGxpbmUiOjE1NzY0MTM3MTB9',
          domain: 'redinnovation.s3-cn-north-1.qiniucs.com',               // bucket域名,下载资源时用到,必需
          get_new_uptoken: false,                                              // 设置上传文件的时候是否每次都重新获取新的uptoken
          auto_start: true,                                                   // 选择文件后自动上传,若关闭需要自己绑定事件触发上传
          max_retries: 3,                                                     // 上传失败最大重试次数
          save_key: true,
          resize: {                                                           // 想限制上传图片尺寸,直接用resize这个属性
            width: 300,
            height: 300
          },
          init: {
            'FilesAdded': function(up, files) {                             // 文件添加进队列后,处理相关的事情
              plupload.each(files, function(file) {
                console.log(file)
              });
            },
            'BeforeUpload': function(up, file) {                            // 每个文件上传前,处理相关的事情
              console.log("开始上传之前");
              $(".upload-progress").show();
            },
            'UploadProgress': function(up, file) {                          // 每个文件上传时,处理相关的事情
              console.log("上传中");
              $(".upload-progress").html("上传进度:"+file.percent + "%");
            },
            'FileUploaded': function(up, file, info) {                       // 每个文件上传成功后,处理相关的事情
              console.log("上传成功");
              console.log(info,4567890);
              $(".upload-progress").hide();
              var img = new Image();                                      //创建一个Image对象,实现图片的预下载
              var res = JSON.parse( info.response )                      // JSON 化响应数据
              console.log('获取的key为:',res.key)          //res= {"hash":"lukJ9k6GzK7ME2bIZEfLDw0uGCDL","key":"lukJ9k6GzK7ME2bIZEfLDw0uGCDL"}
              console.log('获取的hash为:',res.hash)         // key, hash 都是一样的值,取谁都一样,key就是 生成的文件名  域名 + 生成的kye/hash 可直接访问视频
              // debugger
              console.log(ths.qn_url)
              ths.qn_url = ths.qn_url + res.key;
            },
            'Error': function(up, err, errTip) {
              console.log("上传出错")
            },
            'UploadComplete': function() {
              //队列文件处理完毕后,处理相关的事情
            }
          }
        });
      }
    },
    mounted(){
      this.getQiniuToken(() => {
        this.initQiniu()  // 将initQiniu()当做callback回调函数传入给getQiniuToken函数
      })
    }
  }
</script>

<style>
  #container{
    width:200px;
    height:200px;
    border:1px solid #9d9d9d;
    border-radius: 6px;
    margin:50px auto;
    position: relative;
    overflow: hidden;
  }
  .upload-progress{
    width:100%;
    height:100%;
    position: absolute;
    top:0;
    left:0;
    background: rgba(0,0,0,0.5);
    z-index: 5;
    color:#fff;
    line-height: 200px;
    text-align: center;
    display: none;
  }
  #uploadImage{
    width:100%;
    height:100%;
    position: absolute;
    top:0;
    left:0;
    z-index: 2;
    text-align: center;
    line-height: 200px;
    cursor: pointer;
  }
  #container img{
    width:100%;
    position: absolute;
    top:0;
    left:0;
    z-index: 1;
  }
</style>

- 如果报403 而且是 key 与 xxx 不符的错误 ,看下后端获取上传token时传key了,直接把key删了就好
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值