Vue+Flask實現(xiàn)圖片傳輸功能
本文實例為大家分享了Vue+Flask實現(xiàn)圖片傳輸功能的具體代碼,供大家參考,具體內(nèi)容如下
完整流程:
1.圖片轉(zhuǎn)為formdata 傳輸?shù)胶蠖?br />2.后端接收后,確定文件后綴名無誤,修改文件名并保存到固定的路徑中
3.前端請求圖片
4.后端根據(jù)圖片名字返回圖片數(shù)據(jù)流
5.前端將數(shù)據(jù)流處理,轉(zhuǎn)為圖片
1.Vue上傳
<template>
? ? <div>
? ? ? ? <input type="file" class="file" id ='file'>?
? ? ? ? <input type="submit" @click="uploadClick">
? ? </div>
</template>
<script>
export default {
? ?
? ? data () {
? ? ? ? return {}
? ? },
? ? methods:{
? ? ? ? uploadClick(){
? ? ? ? ? ? console.log(document.getElementById('file').files[0]);
? ? ? ? ? ? var formData = new window.FormData()?
? ? ? ? ? ? formData.append('file',document.getElementById('file').files[0])
? ? ? ? ? ? upload(formData)
? ? ? ? ? ??
? ? ? ? } ??
? ? }
}
</script>
//這是封裝的請求
export const upload = (file) => {
? return request({
? ? url: '/api/uavprp/upload',
? ? data: file,
? ? method: 'post',
? ? headers: {?
? ? ? 'Content-Type': 'multipart/form-data'
? ? ?},
? })
}2.Flask接收
#請求中獲取到上傳的圖片
a = request.files.get('file')
#限制文件后綴名必須為圖片的類型
allowed_filename = set(['png', 'jpg', 'JPG', 'PNG'])
isallowed = '.' in filename and filename.rsplit('.', 1)[1] in allowed_filename
path = basedir + "/image/" ?#這里的image是自己創(chuàng)建的保存圖片文件夾路徑
img_name = change_file_name(a.filename,ImgID)#這是我自己定義的一個方法 為了修改圖片的名字為隨機生成的唯一ID,同時不修改后綴名
file_path = path + img_name#完整的保存路徑加圖片名
a.save(file_path)#保存3.Vue請求圖片并轉(zhuǎn)換返回的數(shù)據(jù)流為圖片展示
<template>
?? ?<div>
? ? ? <img :src="ferUrl"/>
? ? </div>
</template>
<script>
export default {
? ?
? ? data () {
? ? ? ? return {
?? ??? ??? ?imgUrl: "",
?? ??? ?}
? ? },
? ? created(){
?? ??? ?getImg("ImgNXTIP298.jpg").then((res) => {
? ? ? ? this.imgUrl = window.URL.createObjectURL(res.data);//這里請求接收的一定是Blod類型數(shù)據(jù)
? ? ? ? console.log(this.imgUrl);
? ? ? });
?? ?}
}
</script>
//封裝的圖片請求
export const getImg = (imgID) => {
? return request({
? ? url: '/api/ferchoosen/getFerImg',
? ? method: 'get',
? ? responseType:"blob",
? ? params: {
? ? ? imgID
? ? }
? })
}4.Flask接收前端請求返回圖片數(shù)據(jù)流
imgID = request.args["imgID"] ? ? if imgID == None: ? ? ? ? return output(msg="該圖片不存在") ? ? path = basedir + "/image/" ? ? image_data = open(os.path.join(path, '%s' % imgID), "rb").read() ? ? response = make_response(image_data) ? ? response.headers['Content-Type'] = 'image/png'#返回的內(nèi)容類型必須修改 ? ? return response
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue實現(xiàn)兩個組件之間數(shù)據(jù)共享和修改操作
這篇文章主要介紹了vue實現(xiàn)兩個組件之間數(shù)據(jù)共享和修改操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11
解決elementui中NavMenu導航菜單高亮問題(解決多種情況)
這篇文章主要介紹了解決elementui中NavMenu?導航菜單高亮問題(解決多種情況),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05
vue + el-tree 實現(xiàn)插入節(jié)點自定義名稱數(shù)據(jù)的代碼
這篇文章主要介紹了vue + el-tree 實現(xiàn)插入節(jié)點自定義名稱數(shù)據(jù)的代碼,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-12-12
VUE中setTimeout和setInterval自動銷毀案例
這篇文章主要介紹了VUE中setTimeout和setInterval自動銷毀案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09
探秘Vue異步更新機制中nextTick的原理與實現(xiàn)
nextTick?是?Vue?提供的一個重要工具,它的作用主要體現(xiàn)在幫助我們更好地處理異步操作,下面就跟隨小編一起來探索一下nextTick的原理與實現(xiàn)吧2024-02-02

