組件上傳圖片到七牛雲

【01】搭建好頁面結構、定義數據與接口後端

<el-upload
method="post"
ref="upload"
:action="domain"
:data="QiniuData"
multiple
:on-exceed="handleExceed"
:on-remove="handleRemove"
:before-remove="beforeRemove"
:before-upload="beforeAvatarUpload"
:on-error="uploadError"
:on-success="uploadSuccess"
:limit="3"
:file-list="fileList"
:auto-upload="false">
<el-button slot="trigger" size="small" type="primary" style="margin-top: 15px;">選取圖片</el-button>
<el-button style="margin-left: 10px;margin-top: 15px;" size="small" type="submit" @click="handleSubmit">上傳圖片</el-button>
<div slot="tip" class="el-upload__tip">只能上傳jpg/png文件,且不超過500kb</div>
</el-upload>
 

data() {
return {
QiniuData: {
key: '',
token: ''
},
domain: 'http://upload.qiniu.com/',
info: {
AccessKey: 'AKKKKKKKKKKKKKKKK',
SecretKey: 'SKKKKKKKKKKKKKKKK',
Bucket: '七牛存儲空間名'
},
uploadPicUrl: '',
fileList: []
}
},

// 上傳圖片張數限制
handleExceed(files, fileList) {
this.$message.warning(
`當前限制選擇 3 張圖片,如需更換,請刪除上一張圖片在從新選擇!`
)
},

// 確認是否刪除準備上傳的圖片
beforeRemove(file, fileList) {
return this.$confirm(`肯定移除${file.name}?`)
},

// 處理刪除事件
handleRemove(file, fileList) {
this.uploadPicUrl = ''
},

// 上傳前檢測圖片格式是否符合提交要求
beforeAvatarUpload(file) {
console.log(file)
const isPNG = file.type === 'image/png'
const isJPEG = file.type === 'image/jpeg'
const isJPG = file.type === 'image/jpg'
const isLt2M = file.size / 1024 / 1024 < 2
if (!isPNG && !isJPEG && !isJPG) {
this.$message.error('上傳頭像圖片只能是 jpg、png、jpeg 格式!')
return false
}
if (!isLt2M) {
this.$message.error('上傳頭像圖片大小不能超過 2MB!')
return false
}
// 檢測完成後,將文件名拼接上隨機數前綴,保存到QiniuData.key中
var randPrefix = this.getNum()
this.QiniuData.key = randPrefix + '_' + `${file.name}`
},

// 上傳成功後執行的回調函數,上傳七牛雲後能夠在這裏面獲得key和hash
uploadSuccess(response, file, fileList) {
this.uploadPicUrl = '七牛雲外鏈默認域名/' + `${response.key}`
console.log('上傳成功!')
console.log('hash:' + response.hash)
console.log('資源連接:' + this.uploadPicUrl)
},

uploadError(response, file, fileList) {
this.$message({
message: '上傳出錯!',
type: 'error',
center: true
})
}
 

【02】從後端獲取上傳憑證token服務器

mounted() {
this.getQiniuToken()
},

methods: {
getQiniuToken() {
this.$http.post('後端接口地址', this.info)
.then(response => {
// console.log(JSON.stringify(response))
if (response.data.Code === 200) {
console.log('獲取token成功!')
this.QiniuData.token = response.data.Data.token
} else {
this.$message({
message: '獲取token失敗!' + response.data.Message,
type: 'error',
center: true
})
}
})
.catch(error => {
this.$message({
message: '獲取token異常!' + error,
type: 'error',
center: true
})
})
}
 

【03】拼接隨機數產生新的圖片名稱keydom

getNum() {
var chars = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
var nums = ''
for (var i = 0; i < 32; i++) {
var id = parseInt(Math.random() * 61)
nums += chars[id]
}
return nums
},
拼接上文件名
var randPrefix = this.getNum()
this.QiniuData.key = randPrefix + '_' + `${file.name}`
 

【04】提交數據到七牛雲服務器函數

handleSubmit() {
console.log('開始上傳……')
console.log(this.QiniuData)
this.$refs.upload.submit()
},
相關文章
相關標籤/搜索