1. 程式人生 > 實用技巧 >實驗室管理系統平臺在實驗室規範運作中的應用

實驗室管理系統平臺在實驗室規範運作中的應用

1.原理圖

2.獲取七牛雲token

from qiniu import Auth

# 七牛雲
class GetTokenView(APIView):
    def get(self,request):
        # 需要填寫你的 Access Key 和 Secret Key
        access_key = 'LT2tyeQHG4vLPyJJdZJNRMFlnodHtmywsrKeOo4L'
        secret_key = 'ojhnC36DPZ2XDYJdWg-2dUScUMxyrgEG2Ok72ywB'
        # 構建鑑權物件
        q = Auth(access_key, secret_key)
        # 要上傳的空間
        bucket_name = 'uu-video'
        # 上傳後儲存的檔名
        # 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, expires=3600, )
        print(token)
        return Response({'uptoken':token})

3.Vue通過token上傳視訊到七牛雲

  • course_show.vue課程頁面下點選新增視訊攜帶課程id跳轉到QnUpload.vue
  • <router-link :to="{name: 'qn_upload', query: {'cid': course.id}}">新增課程</router-link>
  • <router-link :to="'/qn_upload/?id='+id">新增課程</router-link> #兩種方式
getQiniuToken: function (callback){
        qn_token_get({ }).then(resp => {
          // debugger
          console.log(resp)
          this.uptoken = resp.data.uptoken;
          console.log(this.uptoken)
          callback()  // callback 出入的是回撥函式 initQiniu() 用來初始化Qiniu.uploader()
        }).catch( err=>{
          console.log(err,'err')
        })
      },

3.2初始化七牛雲(官方文件)

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:'EKPODOXU_320j3iA2WpNVtG2hfHAPHxY6vhDnSMo:98ANunJRp…6InN5bGltYWdlOiIsImRlYWRsaW5lIjoxNjAyNjY3ODA4fQ==',
          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
              ths.qn_url = ths.qn_url + res.key
              console.log(ths.form_data)
              ths.form_data.video = ths.qn_url
            },
            'Error': function(up, err, errTip) {
              console.log("上傳出錯")
            },
            'UploadComplete': function() {
              //佇列檔案處理完畢後,處理相關的事情
            }
          }
        });
      }

3.3 上傳成功之後拼接出來視訊url

'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
    ths.qn_url = ths.qn_url + res.key
    ths.form_data.video = ths.qn_url
},

3.4 發給django存入資料庫

add_sec(){
    add_sections(this.form_data).then((res)=>{
        console.log(res)
    })
},

3.5 新增節資訊介面

class SectionsApi(APIView):

    def post(self, request):
        print(request.data)
        sections_obj = Sections(
            title=request.data.get('title'),
            serial_num=request.data.get('seriasl_num'),
            chapters=Chapters.objects.get(pk=request.data.get('chapters')),
            learn_time=request.data.get('learn_time'),
            video=request.data.get('video'),
            seq_num=request.data.get('seq_num')
        )
        sections_obj.save()
        return Response({'msg': 'OK', 'code': 200})