實驗室管理系統平臺在實驗室規範運作中的應用
阿新 • • 發佈:2020-10-16
1.原理圖
2.獲取七牛雲token
- 官方文件:https://developer.qiniu.com/kodo/sdk/1242/python
- 在
oauth/views
中
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})