如今,當談論起 RESTful Web API 的時候,人們總會想到 JSON。可是實際上,JSON 和 RESTful API 沒有半毛錢關係,只不過 JSON 剛好是RESTful API 結果的表述格式。也就是說 RESTful API 還可使用其它的表述格式,例如 xml 或私有的格式。這也就意味着,咱們須要讓 RESTful API 知道咱們想要返回的格式。而這就是HTTP請求和響應的核心內容之一: json
內容協商是這樣一個過程:針對一個響應,當有多種表述格式可用的時候,選取最佳的一個表述。 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 所支持,那麼卻是也能夠返回默認的格式,但仍是要儘可能避免這種狀況的出現,其實針對這種狀況最好的辦法是返回 406(Not 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 能夠看做是自描述性這個約束的一部分(每一個消息必須包含足夠的信息來知道如何對它進行處理)。