日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

Django后端分離 使用element-ui文件上傳方式

瀏覽:133日期:2024-09-26 18:46:04

1:導(dǎo)入element

<!-- 引入樣式 --> <link rel='stylesheet' rel='external nofollow' > <!-- 引入組件庫 --> <script src='https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.min.js'></script> <!-- 引入Vue --> <script src='https://unpkg.com/element-ui/lib/index.js'></script>

2:前端文件

css:.avatar-uploader .el-upload { border: 1px dashed #d9d9d9; border-radius: 6px; cursor: pointer; position: relative; overflow: hidden; } .avatar-uploader .el-upload:hover { border-color: #409EFF; } .avatar-uploader-icon { font-size: 28px; color: #8c939d; width: 178px; height: 178px; line-height: 178px; text-align: center; } .avatar { width: 178px; height: 178px; display: block; }html: {% comment %} 上傳圖片 {% endcomment %} <div id='profile'> <h1 >更新社團(tuán)封面</h1> <div style='text-align: center'> <el-upload:data= 'datas'// 攜帶的參數(shù):headers='headers' // 請求頭 name='image' {% comment %} 后端接收的參數(shù)名 {% endcomment %} action='/show/images/' {% comment %} 上傳路由地址 {% endcomment %} :show-file-list='false' :on-success='handleAvatarSuccess' {% comment %} 文件上傳成功時(shí)的鉤子 {% endcomment %} :before-upload='beforeAvatarUpload'> {% comment %} 上傳文件之前的鉤子,參數(shù)為上傳的文件 {% endcomment %}<img v-if='imageUrl' :src='http://m.b3g6.com/bcjs/imageUrl' class='avatar'><i v-else class='el-icon-plus avatar-uploader-icon'></i> </el-upload> </div> </div> {% comment %} 上傳圖片 {% endcomment %}# JS:<script> var Main = { data() { return {headers:{}, // 請求頭是個(gè)對象datas:{}, // 對象imageUrl: ’’ }; },create(){this.headers.authenticate = sessionStorage.getItem(’token’) // 設(shè)置請求頭帶tokenthis.datas.data = 'userHead' // 設(shè)置請求參數(shù)} methods: { handleAvatarSuccess(res, file) {this.imageUrl = URL.createObjectURL(file.raw);console.log('imageUrl',this.imageUrl) }, beforeAvatarUpload(file) {const isJPG = file.type === ’image/jpeg’;const isLt2M = file.size / 1024 / 1024 < 2;if (!isJPG) { this.$message.error(’上傳頭像圖片只能是 JPG 格式!’);}if (!isLt2M) { this.$message.error(’上傳頭像圖片大小不能超過 2MB!’);}return isJPG && isLt2M; } } } var Ctor = Vue.extend(Main) new Ctor().$mount(’#app’)</script>

3:后端文件

路由:# 預(yù)覽圖片url('show/images/$', add_image.Image.as_view()),py文件:from rest_framework.views import APIViewfrom SocietyPlat import settingsfrom django.shortcuts import render, redirect, HttpResponsefrom Databases import modelsfrom django.http import JsonResponseimport os# 獲取相對路徑BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))class Image(APIView): def post(self, request): # 接收文件 file_obj = request.FILES.get(’image’,None) style = requetst.data.get(’data’) # 用戶名 # username = str(request.data.get('username')) username = 'Wang' print('file_obj',file_obj.name) # 判斷是否存在文件夾 head_path = BASE_DIR + 'media{}head'.format(username).replace(' ','') print('head_path',head_path) # 如果沒有就創(chuàng)建文件路徑 if not os.path.exists(head_path): os.makedirs(head_path) # print('文件名',file_obj.name) # 文件名 name.png # # print('文件二進(jìn)制',file_obj.read()) # 文件二進(jìn)制 b’x89PNGrnx1anx00x00x00rIHDRx00x0 # # print('判斷文件> 2.5M',file_obj.multiple_chunks(chunk_size=None)) # 文件大小 False小于2.5M # # print('文件大小',file_obj.size) # 文件大小 12651 # # print('文件編碼',file_obj.charset) # None # # print('隨文件一起上傳的內(nèi)容類型標(biāo)題',file_obj.content_type) # image/png # # print('包含傳遞給content-type標(biāo)頭的額外參數(shù)的字典',file_obj.content_type_extra) # {} # # print('text/content-types提供的utf8字符集編碼',file_obj.charset) # None # # # 圖片后綴 head_suffix = file_obj.name.split('.')[1] print('圖片后綴',head_suffix) # 圖片后綴 png # 儲存路徑 file_path = head_path + '{}'.format('head.' + head_suffix) file_path = file_path.replace(' ','') print('儲存路徑', file_path) # C:UsersuserDesktopDownTestmediausernameheadhead.png # 上傳圖片 with open(file_path, ’wb’) as f: for chunk in file_obj.chunks():f.write(chunk) message = {} message[’code’] = 200 # 返回圖片路徑 back_path = ’static{}head{}’.format(username,'head.' + head_suffix).replace(' ','') message[’image’] = back_path return JsonResponse(message)

補(bǔ)充知識:django后臺接口處理element-ui的el-upload組件form data類型數(shù)據(jù)

對于向我這樣一只前端和后端的雙咸魚來說寫一個(gè)不了解的接口實(shí)在是太難受了,前端不知道在哪找數(shù)據(jù),后端又不知道處理什么樣的數(shù)據(jù)。

現(xiàn)在有這樣一個(gè)需求,我需要使用element-ui中的el-upload組件完成一個(gè)上傳文件的功能。但是不知道是不是因?yàn)槲覜]有發(fā)現(xiàn),我翻遍了官網(wǎng)都沒有找到這個(gè)組件點(diǎn)擊上傳以后發(fā)的是什么樣的數(shù)據(jù)請求。

終于我好像突然想起來瀏覽器的開發(fā)者工具可以查看發(fā)出的請求

于是我們可以寫這么一個(gè)組件來一探究竟:

Django后端分離 使用element-ui文件上傳方式

點(diǎn)擊上傳到服務(wù)器以后前臺就會發(fā)出請求,我們就可以使用devtool看具體的請求頭等等數(shù)據(jù),具體位置在這里:

Django后端分離 使用element-ui文件上傳方式

點(diǎn)擊這個(gè)upload,找一找,我們就會發(fā)現(xiàn)最下面有一個(gè)file

Django后端分離 使用element-ui文件上傳方式

這應(yīng)該就是我們要上傳的文件。可以看見它是以form data的形式上傳的。

所以我們就可以寫對應(yīng)的后端接口了。

這里給一個(gè)接口的demo

def writeFile(filePath, file): with open(filePath, 'wb') as f: if file.multiple_chunks(): for content in file.chunks():f.write(content) else: data=file.read() ###.decode(’utf-8’) f.write(data)def uploadFile(request): if request.method == 'POST': fileDict = request.FILES.items() # 獲取上傳的文件,如果沒有文件,則默認(rèn)為None if not fileDict: return JsonResponse({’msg’: ’no file upload’}) for (k, v) in fileDict: print('dic[%s]=%s' %(k,v)) fileData = request.FILES.getlist(k) for file in fileData:fileName = file._get_name()filePath = os.path.join(settings.TEMP_FILE_PATH, fileName)print(’filepath = [%s]’%filePath)try: writeFile(filePath, file)except: return JsonResponse({’msg’: ’file write failed’}) return JsonResponse({’msg’: ’success’})

另外想要在前端獲取后端返回的請求的話可以使用on-success、on-error、on-exceed這幾個(gè)鉤子函數(shù),具體可以在element ui的官網(wǎng)找到

以上這篇Django后端分離 使用element-ui文件上傳方式就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Django
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲综合二区| 天堂√8在线中文| 久久精品国产99| 亚洲欧美日韩高清在线| 国产欧美一区二区三区精品酒店| 中文字幕免费精品| 亚洲免费毛片| 日韩成人精品一区二区三区 | 国产日韩高清一区二区三区在线| 国产精品2023| 欧美日中文字幕| 成人亚洲一区| 精品免费av在线| 最新中文字幕在线播放| 国产一区调教| 精品亚洲美女网站| 免费精品国产| 粉嫩av一区二区三区四区五区| 青草国产精品| 国产一区二区三区91| 日韩av二区| 欧美日韩国产一区二区三区不卡| 蜜臀91精品国产高清在线观看| 亚洲天堂黄色| 亚洲乱码久久| 国产精品极品| 欧美+日本+国产+在线a∨观看| 欧美va天堂在线| 亚洲中午字幕| 欧美交a欧美精品喷水| 精品久久国产一区| 欧美在线亚洲综合一区| 亚洲一区黄色| 国产精品一区毛片| av中文字幕在线观看第一页| 久久久国产精品一区二区中文| 亚洲精品午夜av福利久久蜜桃| 亚洲欧美专区| 国产传媒在线观看| 午夜在线精品偷拍| 精品视频网站| 视频一区免费在线观看| 国产精品一区二区99| 欧美精品一卡| 狠狠久久伊人| 亚洲一区二区毛片| 狠狠久久伊人中文字幕| 日韩国产一区| 亚洲制服欧美另类| 日韩精品1区| 青草久久视频| 伊人久久亚洲热| 久久男人av资源站| 综合欧美精品| 亚洲国产一区二区三区在线播放| 日韩精品社区| 亚洲一区二区动漫| 日本久久成人网| 欧美三级精品| 婷婷成人av| 亚洲精品九九| 国产精品毛片| 亚洲综合国产| 国产美女亚洲精品7777| 国产一区二区三区四区五区传媒| 精品午夜av| 在线国产一区二区| 日韩精品亚洲专区在线观看| 国产精品日韩精品中文字幕| 亲子伦视频一区二区三区| 亚洲国产日韩欧美在线| 久久国产尿小便嘘嘘| 亚洲欧洲午夜| 婷婷成人综合| 成人羞羞在线观看网站| 国产精品mv在线观看| 欧美另类中文字幕| 亚洲涩涩av| 不卡在线一区二区| 国产亚洲一区二区三区啪| 伊人久久婷婷| 国语对白精品一区二区| 里番精品3d一二三区| 久久www成人_看片免费不卡| 妖精视频成人观看www| 999精品色在线播放| 国产日韩一区二区三区在线播放| 国产极品模特精品一二| 国产在线成人| 美女在线视频一区| 蜜臀精品久久久久久蜜臀| 国产成人久久精品一区二区三区| 亚洲国产专区校园欧美| 精品一二三区| 日韩精品福利一区二区三区| 亚洲一区二区三区免费在线观看 | 日韩美女精品| 日韩在线视频精品| 久久不见久久见中文字幕免费| 91久久久精品国产| 亚洲毛片视频| 中文一区一区三区免费在线观 | 国际精品欧美精品| 91欧美在线| 999久久久国产精品| 欧美va天堂在线| 香蕉久久久久久久av网站| 91大神在线观看线路一区| 国产免费久久| 一区二区三区国产盗摄| 四虎精品永久免费| 电影91久久久| 亚洲精品极品少妇16p| 日韩av中文字幕一区| 精品久久电影| 激情五月综合网| 天堂精品久久久久| 夜鲁夜鲁夜鲁视频在线播放| 免费观看久久久4p| 精品国产aⅴ| 午夜国产精品视频| 久久国产视频网| 久久高清免费| 国产精品久久久久久模特| 久久久777| 国产日韩欧美一区二区三区在线观看| 热三久草你在线| 美美哒免费高清在线观看视频一区二区| 精品久久久网| 日本少妇精品亚洲第一区| 欧美日韩在线播放视频| 国产精品久久久久久久久久妞妞| 欧美在线观看视频一区| 最新中文字幕在线播放| 久久影院一区二区三区| 国产精品亚洲欧美| 日韩高清一级| 免费中文字幕日韩欧美| 99久久99久久精品国产片果冰| 亚洲视频二区| 欧美综合国产| 免费成人性网站| 亚洲日产国产精品| 香蕉精品999视频一区二区| 久久九九精品| 高清不卡亚洲| 人在线成免费视频| 久久99国产精品视频| 日韩高清一级| 国产毛片精品| 精品国产欧美日韩| 国产日韩电影| 亚洲伊人精品酒店| 精品免费视频| 夜久久久久久| 精品国产精品国产偷麻豆 | 国产精品一级| 香蕉久久夜色精品国产| 国产成人精品一区二区三区视频| 好看不卡的中文字幕| 国模精品一区| 欧美精品中文字幕亚洲专区| 免费精品国产的网站免费观看| 精品国产亚洲一区二区在线观看| 日韩午夜av| 久久久天天操| 国产91久久精品一区二区| 亚洲开心激情| 欧美aa在线视频| 97欧美在线视频| 香蕉久久夜色精品国产| 国产精品magnet| 亚洲欧洲一区| 国产精品日本一区二区三区在线| 国产在线日韩精品| 久久国产亚洲| 日本午夜精品| 久久天堂精品| 日韩精品乱码av一区二区| 精品久久久网| 日韩精品乱码av一区二区| 日韩综合在线| 伊人久久成人| 国产精品成人一区二区不卡| 免费欧美一区| 欧美三级网址| 你懂的国产精品永久在线| 99综合视频| 国产不卡一区| 综合一区在线| 国产一区日韩一区| 岛国av在线网站| 欧美激情 亚洲a∨综合| 美女精品一区| 欧美福利在线| 日韩欧美不卡| 另类欧美日韩国产在线| 性一交一乱一区二区洋洋av| 日韩免费福利视频| 国产美女亚洲精品7777|