feign客戶端HTTP狀態(tài)碼為204時(shí)?響應(yīng)體被忽略的問題
feign客戶端HTTP狀態(tài)碼為204時(shí) 響應(yīng)體被忽略
在使用 spring-cloud Greenwich.SR3 時(shí)遇到一個(gè)問題。因?yàn)榉?wù)端HTTP狀態(tài)碼按照rest風(fēng)格設(shè)計(jì),所以u(píng)pdate一類操作的http狀態(tài)碼返回204。
HttpStatus.NO_CONTENT(204, "No Content")*
但是部分接口還是希望返回修改后的數(shù)據(jù)。所以返回體其實(shí)是有內(nèi)容的
return ResponseEntity(data, HttpStatus.NO_CONTENT)
結(jié)果客戶端接收不到data值,修改成普通的200返回就可以收到了。
return ResponseEntity(data, HttpStatus.OK)
猜測(cè)feign對(duì)204狀態(tài)碼做了處理,畢竟204代表響應(yīng)體為空。
HTTP狀態(tài)碼及其含義
開發(fā)Web項(xiàng)目的時(shí)候,因?yàn)榄h(huán)境搭建和配置的原因,經(jīng)常會(huì)出現(xiàn)部署失敗的情況;搭建這個(gè)博客的時(shí)候,也因?yàn)閜hp-admin缺少某些庫的原因,導(dǎo)致出現(xiàn)502的稀有的http狀態(tài)。平時(shí)不是很留意這些狀態(tài)碼信息,也不是很了解出現(xiàn)這種狀態(tài)的內(nèi)在原因,每次出現(xiàn)都要查找。為了詳細(xì)梳理和備忘,整理一份http狀態(tài)碼及其含義的解析。
以下信息參考自:RFC 2616
Http狀態(tài)碼主要有5類:
1XX:信息狀態(tài)碼
100 Continue
:客戶端應(yīng)當(dāng)繼續(xù)發(fā)送請(qǐng)求。這個(gè)臨時(shí)響應(yīng)是用來通知客戶端它的部分請(qǐng)求已經(jīng)被服務(wù)器接收,且仍未被拒絕??蛻舳藨?yīng)當(dāng)繼續(xù)發(fā)送請(qǐng)求的剩余部分,或者如果請(qǐng)求已經(jīng)完成,忽略這個(gè)響應(yīng)。服務(wù)器必須在請(qǐng)求完后向客戶端發(fā)送一個(gè)最終響應(yīng)101 Switching Protocols
:服務(wù)器已經(jīng)理解了客戶端的請(qǐng)求,并將通過Upgrade消息頭通知客戶端采用不同的協(xié)議來完成這個(gè)請(qǐng)求。在發(fā)送完這個(gè)響應(yīng)最后的空行后,服務(wù)器將會(huì)切換到Upgrade消息頭中定義的那些協(xié)議。
2XX:成功狀態(tài)碼
200 OK
:請(qǐng)求成功,請(qǐng)求所希望的響應(yīng)頭或數(shù)據(jù)體將隨此響應(yīng)返回201 Created
:表示服務(wù)器在請(qǐng)求的響應(yīng)中建立了新文檔;應(yīng)在定位頭信息中給出它的URL。202 Accepted
:告訴客戶端請(qǐng)求正在被執(zhí)行,但還沒有處理完。203 Non-Authoritative Information
:表示文檔被正常的返回,但是由于正在使用的是文檔副本所以某些響應(yīng)頭信息可能不正確。(HTTP 1.1新)。204 No Content
:沒有新文檔,瀏覽器應(yīng)該繼續(xù)顯示原來的文檔。如果用戶定期地刷新頁面,而Servlet可以確定用戶文檔足夠新,這個(gè)狀態(tài)代碼是很有用的。205 Reset Content
:沒有新的內(nèi)容,但瀏覽器應(yīng)該重置它所顯示的內(nèi)容。用來強(qiáng)制瀏覽器清除表單輸入內(nèi)容(HTTP 1.1新)。206 Partial Content
:客戶發(fā)送了一個(gè)帶有Range頭的GET請(qǐng)求,服務(wù)器完成了它(HTTP 1.1新)。
3XX:重定向
300 Multiple Choices
:客戶請(qǐng)求的文檔可以在多個(gè)位置找到,這些位置已經(jīng)在返回的文檔內(nèi)列出。如果服務(wù)器要提出優(yōu)先選擇,則應(yīng)該在Location應(yīng)答頭指明。301 Moved Permanently
:客戶請(qǐng)求的文檔在其他地方,新的URL在Location頭中給出,瀏覽器應(yīng)該自動(dòng)地訪問新的URL。302 Found
:類似于301,但新的URL應(yīng)該被視為臨時(shí)性的替代,而不是永久性的。注意,在HTTP1.0中對(duì)應(yīng)的狀態(tài)信息是“Moved Temporatily”。出現(xiàn)該狀態(tài)代碼時(shí),瀏覽器能夠自動(dòng)訪問新的URL,因此它是一個(gè)很有用的狀態(tài)代碼。注意這個(gè)狀態(tài)代碼有時(shí)候可以和301替換使用。例如,如果瀏覽器錯(cuò)誤地請(qǐng)求http://host/~user(缺少了后面的斜杠),有的服務(wù)器 返回301,有的則返回302。嚴(yán)格地說,我們只能假定只有當(dāng)原來的請(qǐng)求是GET時(shí)瀏覽器才會(huì)自動(dòng)重定向。請(qǐng)參見307。303 See Other
:類似于301/302,不同之處在于,如果原來的請(qǐng)求是POST,Location頭指定的重定向目標(biāo)文檔應(yīng)該通過GET提?。℉TTP 1.1新)。304 Not Modified
:客戶端有緩沖的文檔并發(fā)出了一個(gè)條件性的請(qǐng)求(一般是提供If-Modified-Since頭表示客戶只想比指定日期更新的文檔)。服務(wù)器告 訴客戶,原來緩沖的文檔還可以繼續(xù)使用。305 Use Proxy
:客戶請(qǐng)求的文檔應(yīng)該通過Location頭所指明的代理服務(wù)器提?。℉TTP 1.1新)。306 (unused)
:未使用。307 Temporary Redirect
:和302 (Found)相同。許多瀏覽器會(huì)錯(cuò)誤地響應(yīng)302應(yīng)答進(jìn)行重定向,即使原來的請(qǐng)求是POST,即使它實(shí)際上只能在POST請(qǐng)求的應(yīng)答是303時(shí)才能重定 向。由于這個(gè)原因,HTTP 1.1新增了307,以便更加清除地區(qū)分幾個(gè)狀態(tài)代碼:當(dāng)出現(xiàn)303應(yīng)答時(shí),瀏覽器可以跟隨重定向的GET和POST請(qǐng)求;如果是307應(yīng)答,則瀏覽器只 能跟隨對(duì)GET請(qǐng)求的重定向。(HTTP 1.1新)
4XX:客戶端錯(cuò)誤
400 Bad Request
:請(qǐng)求出現(xiàn)語法錯(cuò)誤401 Unauthorized
:客戶試圖未經(jīng)授權(quán)訪問受密碼保護(hù)的頁面。應(yīng)答中會(huì)包含一個(gè)WWW-Authenticate頭,瀏覽器據(jù)此顯示用戶名字/密碼對(duì)話框,然后在填 寫合適的Authorization頭后再次發(fā)出請(qǐng)求。402 Payment Required
:未使用。403 Forbidden
:資源不可用。服務(wù)器理解客戶的請(qǐng)求,但拒絕處理它。通常由于服務(wù)器上文件或目錄的權(quán)限設(shè)置導(dǎo)致。404 Not Found
:無法找到指定位置的資源。這也是一個(gè)常用的應(yīng)答。405 Method Not Allowed
:請(qǐng)求方法(GET、POST、HEAD、DELETE、PUT、TRACE等)對(duì)指定的資源不適用。(HTTP 1.1新)406 Not Acceptable
:指定的資源已經(jīng)找到,但它的MIME類型和客戶在Accpet頭中所指定的不兼容(HTTP 1.1新)。407 Proxy Authentication Required
:類似于401,表示客戶必須先經(jīng)過代理服務(wù)器的授權(quán)。(HTTP 1.1新)408 Request Timeout
:在服務(wù)器許可的等待時(shí)間內(nèi),客戶一直沒有發(fā)出任何請(qǐng)求??蛻艨梢栽谝院笾貜?fù)同一請(qǐng)求。(HTTP 1.1新)409 Conflict
:通常和PUT請(qǐng)求有關(guān)。由于請(qǐng)求和資源的當(dāng)前狀態(tài)相沖突,因此請(qǐng)求不能成功。(HTTP 1.1新)410 Gone
:所請(qǐng)求的文檔已經(jīng)不再可用,而且服務(wù)器不知道應(yīng)該重定向到哪一個(gè)地址。它和404的不同在于,返回407表示文檔永久地離開了指定的位置,而 404表示由于未知的原因文檔不可用。(HTTP 1.1新)411 Length Required
:服務(wù)器不能處理請(qǐng)求,除非客戶發(fā)送一個(gè)Content-Length頭。(HTTP 1.1新)412 Precondition Failed
:請(qǐng)求頭中指定的一些前提條件失?。℉TTP 1.1新)。413 Request Entity Too Large
:目標(biāo)文檔的大小超過服務(wù)器當(dāng)前愿意處理的大小。如果服務(wù)器認(rèn)為自己能夠稍后再處理該請(qǐng)求,則應(yīng)該提供一個(gè)Retry-After頭(HTTP 1.1新)。414 Request-URI Too Long
:URI太長(HTTP 1.1新)。415 Unsupported Media Type
:請(qǐng)求所帶的附件的格式類型服務(wù)器不知道如何處理。(HTTP 1.1新)416 Requested Range Not Satisfiable
:服務(wù)器不能滿足客戶在請(qǐng)求中指定的Range頭。(HTTP 1.1新)417 Expectation Failed
:如果服務(wù)器得到一個(gè)帶有100-continue值的Expect請(qǐng)求頭信息,這是指客戶端正在詢問是否可以在后面的請(qǐng)求中發(fā)送附件。在這種情況下,服務(wù)器也會(huì)用該狀態(tài)(417)告訴瀏覽器服務(wù)器不接收該附件或用100 (SC_CONTINUE)狀態(tài)告訴客戶端可以繼續(xù)發(fā)送附件。(HTTP 1.1新)
5XX: 服務(wù)器錯(cuò)誤
500 Internal Server Error
:服務(wù)器遇到了意料不到的情況,不能完成客戶的請(qǐng)求。501 Not Implemented
:服務(wù)器不支持實(shí)現(xiàn)請(qǐng)求所需要的功能。例如,客戶發(fā)出了一個(gè)服務(wù)器不支持的PUT請(qǐng)求。502 Bad Gateway
:服務(wù)器作為網(wǎng)關(guān)或者代理時(shí),為了完成請(qǐng)求訪問下一個(gè)服務(wù)器,但該服務(wù)器返回了非法的應(yīng)答。503 Service Unavailable
:服務(wù)器由于維護(hù)或者負(fù)載過重未能應(yīng)答。例如,Servlet可能在數(shù)據(jù)庫連接池已滿的情況下返回503。服務(wù)器返回503時(shí)可以提供一個(gè) Retry-After頭。504 Gateway Timeout
:由作為代理或網(wǎng)關(guān)的服務(wù)器使用,表示不能及時(shí)地從遠(yuǎn)程服務(wù)器獲得應(yīng)答。(HTTP 1.1新)505 HTTP Version Not Supported
:服務(wù)器不支持請(qǐng)求中所指明的HTTP版本。(HTTP 1.1新)
以上是各種http狀態(tài)碼的含義,熟悉了以上信息,在Web開發(fā)中對(duì)于debug有很大的意義,可以更快地定位到bug所在。希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java根據(jù)模板實(shí)現(xiàn)excel導(dǎo)出標(biāo)準(zhǔn)化
這篇文章主要為大家詳細(xì)介紹了Java如何根據(jù)模板實(shí)現(xiàn)excel導(dǎo)出標(biāo)準(zhǔn)化,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,有需要的小伙伴可以參考下2024-03-03Mybatis中使用萬能的Map傳參實(shí)現(xiàn)
在編程中,有可能遇到我們的實(shí)體類或者數(shù)據(jù)庫中表的字段或參數(shù)過多的情況,那這時(shí)候用Map傳參是比較理想的選擇,本文就詳細(xì)的介紹一下如何使用,感興趣的可以了解下2021-07-07java List循環(huán)與Map循環(huán)的總結(jié)
這篇文章主要介紹了java List循環(huán)與Map循環(huán)的總結(jié)的相關(guān)資料,并附代碼實(shí)例,幫助大家學(xué)習(xí)理解,需要的朋友可以參考下2016-11-11java中的日期時(shí)間類Date和SimpleDateFormat
這篇文章主要介紹了java中的日期時(shí)間類Date和SimpleDateFormat,Date類的對(duì)象在Java中代表的是當(dāng)前所在系統(tǒng)的此刻日期時(shí)間,說白了就是你計(jì)算機(jī)上現(xiàn)實(shí)的時(shí)間,需要的朋友可以參考下2023-09-09Java NIO Selector用法詳解【含多人聊天室實(shí)例】
這篇文章主要介紹了Java NIO Selector用法,結(jié)合實(shí)例形式分析了Java NIO Selector基本功能、原理與使用方法,并結(jié)合了多人聊天室實(shí)例加以詳細(xì)說明,需要的朋友可以參考下2019-11-11java使用EasyExcel實(shí)現(xiàn)Sheet的復(fù)制與填充
EasyExcel是一個(gè)非常有用的工具,它提供了強(qiáng)大的模板填充功能,可以輕松解決各種業(yè)務(wù)需求,本文主要為大家介紹了如何使用EasyExcel實(shí)現(xiàn)模板Sheet復(fù)制與填充,需要的可以參考下2023-10-10