成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

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

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

1:導入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 >更新社團封面</h1> <div style='text-align: center'> <el-upload:data= 'datas'// 攜帶的參數:headers='headers' // 請求頭 name='image' {% comment %} 后端接收的參數名 {% endcomment %} action='/show/images/' {% comment %} 上傳路由地址 {% endcomment %} :show-file-list='false' :on-success='handleAvatarSuccess' {% comment %} 文件上傳成功時的鉤子 {% endcomment %} :before-upload='beforeAvatarUpload'> {% comment %} 上傳文件之前的鉤子,參數為上傳的文件 {% endcomment %}<img v-if='imageUrl' :src='http://www.piao2010.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:{}, // 請求頭是個對象datas:{}, // 對象imageUrl: ’’ }; },create(){this.headers.authenticate = sessionStorage.getItem(’token’) // 設置請求頭帶tokenthis.datas.data = 'userHead' // 設置請求參數} 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:后端文件

路由:# 預覽圖片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) # 如果沒有就創建文件路徑 if not os.path.exists(head_path): os.makedirs(head_path) # print('文件名',file_obj.name) # 文件名 name.png # # print('文件二進制',file_obj.read()) # 文件二進制 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('隨文件一起上傳的內容類型標題',file_obj.content_type) # image/png # # print('包含傳遞給content-type標頭的額外參數的字典',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)

補充知識:django后臺接口處理element-ui的el-upload組件form data類型數據

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

現在有這樣一個需求,我需要使用element-ui中的el-upload組件完成一個上傳文件的功能。但是不知道是不是因為我沒有發現,我翻遍了官網都沒有找到這個組件點擊上傳以后發的是什么樣的數據請求。

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

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

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

點擊上傳到服務器以后前臺就會發出請求,我們就可以使用devtool看具體的請求頭等等數據,具體位置在這里:

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

點擊這個upload,找一找,我們就會發現最下面有一個file

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

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

所以我們就可以寫對應的后端接口了。

這里給一個接口的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() # 獲取上傳的文件,如果沒有文件,則默認為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這幾個鉤子函數,具體可以在element ui的官網找到

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

標簽: Django
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
亚洲福利视频一区二区| 亚洲一级片在线观看| 亚洲免费成人av| 欧美二区在线| 久久久亚洲精华液精华液精华液| 国产河南妇女毛片精品久久久 | 欧美aa国产视频| 欧美不卡在线视频| 成人在线视频一区二区| 日韩欧美国产综合| 国模无码大尺度一区二区三区| 在线免费精品视频| 日本成人中文字幕在线视频| 色婷婷综合久久久中文一区二区| 亚洲福利一二三区| 色综合久久精品| 亚洲成av人片在线观看无码| 免费在线播放第一区高清av| 丝袜诱惑制服诱惑色一区在线观看 | 国产精品另类一区| 国产99久久久国产精品潘金网站| 欧美性视频一区二区三区| 免费在线观看成人| 欧美性受xxxx黑人xyx性爽| 精品一区二区av| 欧美一区二区三区免费观看视频| 成人综合婷婷国产精品久久蜜臀| 精品国产免费一区二区三区四区| av在线播放不卡| 国产欧美日韩精品在线| 欧美日韩一区二区三区四区在线观看 | 日韩免费在线观看| 国产一区二区三区国产| 欧美日韩一二区| 国产一区二区三区香蕉| 欧美一区二区美女| 色综合天天在线| 国产精品成人午夜| 亚洲精品社区| 亚洲bdsm女犯bdsm网站| 日本国产一区二区| 国产精一区二区三区| 欧美精品一区二区精品网| 欧美全黄视频| 亚洲黄色免费网站| 久久狠狠一本精品综合网| 免费观看在线综合色| 欧美日本一道本在线视频| 国产成人av资源| 久久精品人人做人人爽人人| 影音先锋久久资源网| 亚洲成av人影院在线观看网| 欧美日本韩国一区二区三区视频| 成人va在线观看| 亚洲欧洲日韩av| 久久午夜av| 国产·精品毛片| 国产精品美女久久久久aⅴ国产馆| 一区二区91| 久久国产欧美日韩精品| 精品国产自在久精品国产| 精品69视频一区二区三区Q| 亚洲制服丝袜一区| 欧美日韩在线播| 欧美国产综合| 亚洲成人综合网站| 欧美一三区三区四区免费在线看| 午夜国产精品视频| 香蕉乱码成人久久天堂爱免费| 欧美美女激情18p| 欧美激情视频一区二区三区免费| 亚洲午夜av在线| 69堂亚洲精品首页| 亚洲婷婷在线| 另类人妖一区二区av| 久久影院午夜论| 国产亚洲欧美一区二区 | 国产精品欧美久久久久无广告 | 精品福利av| 极品少妇一区二区| 国产午夜精品美女毛片视频| 亚洲专区一区二区三区| 国产黑丝在线一区二区三区| 亚洲人成影院在线观看| 色哟哟国产精品| 91网站最新地址| 午夜欧美一区二区三区在线播放| 欧美蜜桃一区二区三区| 欧美精品啪啪| 日本女优在线视频一区二区| 久久精品一区二区三区不卡 | 久久久久国产精品厨房| 一本色道久久综合亚洲91| 成人av一区二区三区| 亚洲国产乱码最新视频| 日韩欧美一级精品久久| 一本色道久久综合亚洲精品高清 | 日韩一区二区三区四区 | 99亚偷拍自图区亚洲| 婷婷国产在线综合| 国产三级一区二区三区| 色哟哟国产精品免费观看| 欧美精品91| 狠狠色丁香九九婷婷综合五月| 一区视频在线播放| 欧美一区二区国产| 欧美亚洲在线| 91女厕偷拍女厕偷拍高清| 免费亚洲电影在线| 国产精品人妖ts系列视频| 91精品国产一区二区三区蜜臀| 国产精品一区在线播放| av电影一区二区| 蜜桃视频一区二区| 日韩理论在线观看| 日韩欧美一区二区视频| 美女日韩在线中文字幕| 欧美高清一区| 国产高清在线精品| 午夜久久久久久久久| 国产精品嫩草久久久久| 欧美电影影音先锋| 亚洲自拍高清| 亚洲网友自拍| a美女胸又www黄视频久久| 乱中年女人伦av一区二区| 亚洲精品中文在线| 久久久精品日韩欧美| 精品视频在线视频| 香蕉久久a毛片| 国产精品二区影院| 成人教育av在线| 麻豆传媒一区二区三区| 亚洲午夜激情av| 亚洲日本中文字幕区| 久久久精品国产免大香伊| 678五月天丁香亚洲综合网| 久久激情中文| 99精品视频免费观看视频| 欧美啪啪一区| 91老司机福利 在线| 国产jizzjizz一区二区| 日韩成人午夜电影| 亚洲精品国产精品乱码不99| 国产女人aaa级久久久级| 欧美白人最猛性xxxxx69交| 欧美日韩大陆在线| 在线看日本不卡| 一本高清dvd不卡在线观看| 最新国产乱人伦偷精品免费网站| www.亚洲在线| 国产69精品久久久久777| 久久成人综合网| 婷婷成人激情在线网| 亚洲午夜久久久久中文字幕久| 国产精品久久久一本精品| 国产亚洲一区二区三区在线观看| 日韩一级高清毛片| 欧美精品tushy高清| 欧美三电影在线| 欧美在线观看你懂的| 久久精品女人的天堂av| 国产女优一区| 国产视频一区在线观看一区免费| 亚洲动漫精品| 极品中文字幕一区| 亚洲无线观看| 欧美在线日韩精品| 色综合天天综合在线视频| 女人色偷偷aa久久天堂| av电影在线观看完整版一区二区| 成人黄色av电影| 国产福利一区二区三区视频| 国产一区二区三区免费看| 国产一区在线看| 国产精品99久| 成人av影视在线观看| 97精品久久久久中文字幕 | 欧美一区二区三区四区在线观看地址 | 国产精品分类| 91麻豆国产福利在线观看| 91首页免费视频| 欧美激情 亚洲a∨综合| 狠久久av成人天堂| 亚洲人成人一区二区三区| 亚洲精选久久| 在线视频欧美一区| 国产精品夜夜夜一区二区三区尤| 国产欧美一区二区三区另类精品 | 国内精品久久久久久久97牛牛| 欧美日韩成人一区二区三区| 欧美日韩国产综合视频在线| 影音欧美亚洲| 国产欧美日韩在线播放| 久久久精品五月天| 欧洲一区二区av| 欧美一区二区视频免费观看| 精品国产一区久久| 中文字幕字幕中文在线中不卡视频| 亚洲理论在线观看|