您好,登錄后才能下訂單哦!
更改默認的content type
根據響應體中指定的scala值,可以自動地推斷出結果的content type,舉例如下:
val textResult = Ok("Hello World!")
這將自動地把content-type的頭部設置成text/plain,同時:
val xmlResult = Ok(<message>Hello World!</message>)
這個會把頭部設置成application/xml
以上通過play.api.http.ContentTypeOf這個類來實現。用
as(newContentType)可以強制轉換header的content type,
val htmlResult = Ok(<h2>Hello World!</h2>).as("text/html")
或者如下:
val htmlResult2 = Ok(<h2>Hello World!</h2>).as(HTML)
使用HTML類型,頭部會被自動設置成
text/html; charset=utf-8。
可以在結果中添加HTTP頭部:
val result = Ok("Hello World!").withHeaders(
CACHE_CONTROL -> "max-age=3600",
ETAG -> "xx")
Cookies是一個特殊格式的HTTP頭部,使用一系列的幫助類使他變得更容易。把Cookies加入到HTTP響應中:
val result = Ok("Hello world").withCookies(
Cookie("theme", "blue"))
丟棄瀏覽器存放的cookies:
val result2 = result.discardingCookies(DiscardingCookie("theme"))
兩者還可以混用:
val result3 = result.withCookies(Cookie("theme", "blue")).discardingCookies(DiscardingCookie("skin"))
更改文本類型的HTTP響應的字符集
HTTP響應默認使用utf-8
字符集不僅用來把文本響應轉換成對應的字節流,進行網絡傳輸, 而且用";charset=xxx"來更新content-type頭部。
通過play.api.mvc.Codec這個類,字符集被自動處理。在當前范圍內,導入
play.api.mvc.Codec這個隱式類可以更改字符集,用以下的方式操作:
class Application extends Controller {
implicit val myCustomCharset = Codec.javaSupported("iso-8859-1")
def index = Action {
Ok(<h2>Hello World!</h2>).as(HTML)
}
}
關于HTML的定義:
def HTML(implicit codec: Codec) = {
"text/html; charset=" + codec.charset
}
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。