1. 程式人生 > 實用技巧 >七牛雲上傳視訊

七牛雲上傳視訊

目錄

使用七牛雲上傳視訊

方便筆記只寫了上傳視訊要使用到的程式碼

在django端獲取七牛雲的token

# models.py中定義課程節表
class Sections(Base):
    title = models.CharField("節標題", max_length=24)
    seriasl_num = models.IntegerField("節序號")
    chapters = models.ForeignKey(Chapters, related_name="sections", on_delete=models.SET_NULL, null=True)
    learn_time = models.IntegerField("學習小時", default=1)
    video = models.FileField("上傳視訊", upload_to='videos/%Y%m%d/',blank=True, max_length=1024)
    seq_num = models.IntegerField("序號", default=1)

    class Meta:
        db_table = "tb_sections"

    def __str__(self):
        return self.title
# 在views.py中獲取七牛雲token(檢視官方文件https://developer.qiniu.com/kodo/sdk/1242/python)

# 獲取七牛雲的token
class QuToken(APIView):

    def get(self, request):
        # 需要填寫你的 Access Key 和 Secret Key
        access_key = 'kZNzrg7Mzq458AurbinXPwsxiBZwb2cowx660A5E'
        secret_key = 'QMthpVgv6rlLcmJoZ0VYQlF3qEsHhrk35_B19B6B'
        # 構建鑑權物件
        q = Auth(access_key, secret_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'
        }

        # 要上傳的空間
        bucket_name = 'sylimages'

        # 生成上傳 Token,可以指定過期時間等
        token = q.upload_token(bucket_name, expires=3600)

        return Response({'uptoken': token})

vue端程式碼

<template>
  <div>
    <p>節標題: <input type="text" v-model="from_data.title"></p>
    <p>節序號: <input type="number" v-model="from_data.seriasl_num"></p>
    <p>學習小時: <input type="text" v-model="from_data.learn_time"></p>
    <p>所屬章節:
      <select v-model="from_data.chapters">
        <option :value="i.id" v-for="i in course_data.chapters" :key="i.id">{{i.title}}</option>
      </select>
    </p>
    <p>序列: <input type="text" v-model="from_data.seq_num"></p>
      <!-- 1.上傳時的點選框  -->
    <div id="container">
      <div>
        <div id="uploadImage">選擇檔案{{uptoken}}</div>
        <div class="upload-progress"></div>
      </div>
    </div>
  </div>
</template>

<script>
  import $ from 'jquery'
  // 使用已經封裝好的請求
  import { qn_token_get,course_get,insert_video } from './axios_api/api' 

  export default {
    data() {
      return {
        uptoken: '',
        qn_url: 'http://qi67pmgey.hn-bkt.clouddn.com/',
        cid: this.$route.query.cid, // 章id,前一個頁面跳轉來時攜帶的id
        course_data: {},
        from_data: {
          "title": "",
          "seriasl_num": "",
          "learn_time": "",
          "chapters": 1,
          "video": "",
          "seq_num": ""    // 準備要傳送到後端的資料
        }
      };
    },
    methods: {
      add_sql(){
        console.log(this.from_data)
        insert_video(this.from_data).then((resp) => {
          console.log(resp)
        })
      },
      get_course(){
        course_get({'id': this.cid}).then((resp) => {
          this.course_data = resp
        })
      },
      //  請求後臺獲取七牛雲token
      getQiniuToken: function (callback){
        qn_token_get({ }).then(resp => {
          // debugger
          this.uptoken = resp.uptoken;
          console.log(this.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 )
              // debugger
              console.log("url>>>>>>",ths.qn_url)
              ths.qn_url = ths.qn_url + res.key;  // 將路由拼接成視訊的路由
              ths.from_data.video = ths.qn_url  // 將拼接好的視訊路由存入from_data中準備傳送到後端存入資料庫
            },
            'Error': function(up, err, errTip) {
              console.log("上傳出錯")
            },
            'UploadComplete': function() {                    //佇列檔案處理完畢後,處理相關的事情
            }
          }
        });
      }
    },
    mounted(){
      this.get_course()
      this.getQiniuToken(() => {
        this.initQiniu()  // 將initQiniu()當做callback回撥函式傳入給getQiniuToken函式
      })
    }
  }
</script>

在後端把vue中的傳來的資料進行儲存

# video直接儲存視訊的路由

# 將存在七牛雲的視訊地址存在資料庫
class Insert_video(APIView):

    def post(self, request):
        data = request.data
        print(data)
        section_obj = Sections(title=data.get("title"),
                               seriasl_num=data.get("seriasl_num"),
                               learn_time=data.get("learn_time"),
                               														chapters=Chapters.objects.get(pk=data.get("chapters")),
                               video=data.get("video"),
                               seq_num=data.get("seq_num"))
        section_obj.save()

        return Response({"code":200, "msg": "成功"})