1.七牛雲上傳前台頁面
1.1 安裝相關包
npm install --save jquery@1.12.1 # 安裝jquery
1.2 index.html 引入qiniu.min.js
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<title>qiniu_vue</title>
<script src="./static/qiniu.min.js"></script>
</head>
<body>
<div id="app"></div>
<!-- built files will be auto injected -->
</body>
</html>
1.3 新建 components\QnUpload.vue 上傳視頻頁面
<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'
import { qn_token_get } from './axios_api/api'
export default {
data() {
return {
uptoken: '', // 從django后端獲取的七牛雲
認證token
qn_url: 'http://qi11dgv17.hn-bkt.clouddn.com/', // 七牛雲給的空間測試域名
};
},
methods: {
// 1.獲取七牛雲認證token
getQiniuToken: function (callback){
qn_token_get({ }).then(resp => {
// debugger
this.uptoken = resp.data.uptoken;
callback() // callback 出入的是回調函數 initQiniu() 用來初始化
Qiniu.uploader()
}).catch( err=>{
console.log(err,'err')
})
},
// 2.初始化七牛雲對象
initQiniu: function () {
var ths = this // 避免七牛雲對象覆蓋vue的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:'q06bq54Ps5JLfZyP8AxqvByMBdu8AoIVJpMco2m:kyTiuN6GBUpfNt1nJIA7C8CCStY=:eyJzY29wZSI6IjEzMTIzMTIzMTIzIiw
iZGVhZGxpbmUiOjE1NzY0MTM3MTB9',
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(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>
1.4 router\index.js 引入路由
import qn_upload from '@/components/QnUpload'
var routes = [
{ path: '/qn_upload/', name: 'qn_upload', component: qn_upload,},
]
1.5 axios_api\api.js 中引入后端路由
export const qn_token_get = p => axios_get("/oauth/qntoken/", p) // 獲取七牛雲token
2.測試頁面結果

