<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
後端:實現了一個檔案上傳服務介面,可以接收前端傳遞過來的MultipartFile檔案,並儲存到伺服器本地中。
前端:獲取type
為file
的<font>
標籤中的檔案,使用axios
http請求庫,傳送post
請求,將檔案傳送給後端。
在js中傳送上傳檔案請求的常規程式碼如下:
new
一個FormData
物件,使用append
方法將檔案新增到表單中FormData
專門用於js中傳送multipart/form-data
格式請求append
方法的key
為表單中的name
屬性,即後端需要接收的引數名async handleUploadFile(event) { const file = event.target.files[0] let formData = new FormData() formData.append('files', file) const res = await service({ url: '/api/files/upload', method: 'POST', headers: { 'Content-Type': 'multipart/form-data' }, data: formData }) console.log(res.data); }
實際執行以上這段程式碼時,會發現後端報500
錯誤如下:
Caused by: java.io.IOException:
org.apache.tomcat.util.http.fileupload.FileUploadException: the request was rejected because no multipart boundary was found
大概的意思是說,後端無法識別到傳遞來的檔案中的boundary
,從而無法區分一個檔案的內容從報文的哪個地方開始,又從報文的哪個地方結束,最終導致檔案上傳失敗。
分析以上這種情況的原因,是因為我在傳送請求時將請求頭中Content-Type
屬性給寫死為multipart/form-data
,瀏覽器無法自動給我們的報文新增boundary
我嘗試將前端請求config
中,headers
設定移除,如下:
async handleUploadFile(event) { const file = event.target.files[0] let formData = new FormData() formData.append('files', file) const res = await service({ url: '/api/files/upload', method: 'POST', data: formData }) console.log(res.data); }
再次傳送請求,這次仍然沒有請求成功。伺服器沒有報錯了,但是後端獲取不到檔案資料。繼續分析請求報文,發現屬性值變為application/x-www-form-urlencoded
,這是傳送普通的表單,肯定是無法正確將檔案送達的。
在查閱了網上大量的貼文之後得知,axios
在請求傳送出去之前會進行一次攔截,自動給我們的請求設定一些引數。上面會出現application/x-www-form-urlencoded
這個引數就是因為axios
設定了post
請求的預設請求頭,如果我們沒有在config
中指定其它請求頭的話,就會使用預設的。
又瞭解到,傳送multipart/form-data
格式的請求時,不需要我們自己指定Content-Type
屬性,由瀏覽器自動幫我們去設定。
那麼解決問題的關鍵就是不讓axios
幫我們自動設定
axios
的config
中有一個transformRequest
屬性,官方的解釋是可以在請求傳送之前讓我們人為干預。屬性值是一個陣列,裡面可以定義一個函數,接收兩個引數,分別是data
和headers
。data
就是我們剛剛定義的FormData
物件,headers
裡面則是axios
預定義的請求頭。
列印headers
:
將post
屬性中的Content-Type
屬性刪掉即可解決問題。
最終程式碼如下:
async handleUploadFile(event) { const file = event.target.files[0] let formData = new FormData() formData.append('files', file) const res = await service({ url: '/api/files/upload', method: 'POST', transformRequest: [function(data, headers) { // 去除post請求預設的Content-Type delete headers.post['Content-Type'] return data }], data: formData }) console.log(res.data); }
以上的解決方法是我不斷試錯之後得出來的,網上關於這個問題的很多貼文都不能解決,氣死我了。。。希望這篇貼文能幫助大家避免踩這個坑吧~
到此這篇關於如何使用axios傳送post請求上傳檔案到後端(multipart/form-data)的文章就介紹到這了,更多相關axios傳送post請求上傳檔案內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45