七牛云
1、使用python获取上传使用的token值
-
安装七牛云
pip install qiniu==7.2.6
-
获取token,这里是使用的工用方法,在utils下创建MyBaseView.py文件
from qiniu import Auth
# 七牛云上传视屏生成token
def qiniu_token():
# 需要填写你的 Access Key 和 Secret Key
access_key = 'RHBatQttI9aPJvTMslxxSCilmmYZzOL2At0Tx6gm'
secret_key = '1S860TXxZP5ihW21aNZyvXdKSZCrWbknBIy6DU4K'
# 构建鉴权对象
q = Auth(access_key, secret_key)
# 要上传的空间
bucket_name = '12345678900'
# 3600为token过期时间,秒为单位。3600等于一小时
token = q.upload_token(bucket_name, expires=3600)
return token
- 在views.py里使用qiniu_token
class QiNiuToken(APIView):
def get(self,request):
token = qiniu_token()
print(token)
data = {
'code':0,
'msg':'获取token成功',
'data':{
'uptoken':token
}
}
return Response(data
- 定义URl
from django.urls import path
from . import views
urlpatterns = [
path('uptoken/', views.QiNiuToken.as_view()), # 获取七牛云上传凭证
]
2、在vue里面写入的内容
<template>
<div>
<input type="file" name='upFile' id="upFile" @change='changeFile($event)'>
<input type="button" name="开始上传" value="开始上传" @click='uploadFile()'>
<img v-if="coverUrl" :src="coverUrl" alt="封面">
<el-progress :percentage="filePercent"></el-progress>
{{filePercent}}
</div>
</template>
<script>
import * as qiniu from "qiniu-js";
export default {
name:'qiniu',
data() {
return {
file:null,
videoUrl:null,
coverUrl:null,
filePercent:0
};
},
methods: {
changeFile(e){
// 获取文件
this.file = e.target.files[0];
},
// 获取uptoken
get_uptoken() {
axios({
url: 'http://127.0.0.1:8000/day01/uptoken/',
method: 'get'
}).then(res=>{
this.uptoken = res.data.token
})
},
uploadFile() {
// 当前VUE中的this 是指向实例,相当于父级,指向指不到子级中。所需需要一个变量 _this 存储this得指向。
let _this = this
// 获取身份的token
let token = _this.uptoken
// 上传时的配置
var config = {
useCdnDomain: true
};
// 设置文件的配置
var putExtra = {
fname: "",
params: {},
mimeType: null
};
// 实例化七牛云的上传实例
var observable = qiniu.upload(_this.file, null, token, putExtra, config);
// 设置实例的监听对象
var observer = {
// 接收上传进度信息
next(res) {
// 上传进度
_this.filePercent = parseInt(res.total.percent)
if(_this.filePercent==100){
console.log("success")
}
},
// 接收上传错误信息
error(err) {
console.log(err)
},
// 接收上传完成后的信息
complete(res) {
console.log(res.key)
}
};
// 上传开始
var subscription = observable.subscribe(observer);
}
},
mounted() {
this.get_uptoken()
}
}
</script>