使用ASP.NET Core 3.x 構建 RESTful API - 3.4 內容協商

如今,當談論起 RESTful Web API 的時候,人們總會想到 JSON。可是實際上,JSON  RESTful API 沒有半毛錢關係,只不過 JSON 剛好是RESTful API 結果的表述格式。也就是說 RESTful API 還可使用其它的表述格式,例如 xml 或私有的格式。這也就意味着,咱們須要讓 RESTful API 知道咱們想要返回的格式。而這就是HTTP請求和響應的核心內容之一: json

 

Content Negotiation 內容協商 

內容協商是這樣一個過程:針對一個響應,當有多種表述格式可用的時候,選取最佳的一個表述。 app

 

當咱們的RESTful API只面向一個API消費者的時候,也許只使用 JSON 一種格式是沒有什麼問題的。可是若是須要面向各類形式的多個API消費者,那麼頗有可能少數API消費者沒法很好的解析JSON,它們可能更習慣於xml或者其它格式。 spa

 

那麼如何解決這個問題呢? orm

HTTP請求的 Accept Header 就是用來解決這個問題的,API的消費者在發送請求的時候,在Accept Header 裏面填寫好 Media Type(媒體類型),例如 application/json 或者 application/xml等等。 xml

若是請求裏填寫的是 application/json,那麼RESTful API返回響應的表述格式就應該是 json io

 

而若是請求沒有填寫 Accept Header,那麼 RESTful API 只好使用它的默認格式進行響應了。 table

若是在 Accept Header 裏面填寫的格式不被 RESTful API 所支持,那麼卻是也能夠返回默認的格式,但仍是要儘可能避免這種狀況的出現,其實針對這種狀況最好的辦法是返回 406Not Acceptable 狀態碼,表示 API消費者請求的媒體類型是不可接受的,沒法將其做爲響應的格式。 ast

 

綜上,Accept Header 指的是輸出格式。 form

 ASP.NET Core 裏面對應的就是 Output Formatters class

 

而用於指定輸入格式的 Header Content-Type,在 ASP.NET Core 裏面對應的就是 Input formatter 

例如 POST 請求的 body 就須要經過指定 Content-Type 來進行標識,這個 Header 能夠看做是自描述性這個約束的一部分(每一個消息必須包含足夠的信息來知道如何對它進行處理)。

相關文章
相關標籤/搜索