您好,登錄后才能下訂單哦!
更改默認(rèn)的content type
根據(jù)響應(yīng)體中指定的scala值,可以自動(dòng)地推斷出結(jié)果的content type,舉例如下:
val textResult = Ok("Hello World!")
這將自動(dòng)地把content-type的頭部設(shè)置成text/plain,同時(shí):
val xmlResult = Ok(<message>Hello World!</message>)
這個(gè)會(huì)把頭部設(shè)置成application/xml
以上通過(guò)play.api.http.ContentTypeOf這個(gè)類來(lái)實(shí)現(xiàn)。用
as(newContentType)可以強(qiáng)制轉(zhuǎn)換header的content type,
val htmlResult = Ok(<h2>Hello World!</h2>).as("text/html")
或者如下:
val htmlResult2 = Ok(<h2>Hello World!</h2>).as(HTML)
使用HTML類型,頭部會(huì)被自動(dòng)設(shè)置成
text/html; charset=utf-8。
可以在結(jié)果中添加HTTP頭部:
val result = Ok("Hello World!").withHeaders(
CACHE_CONTROL -> "max-age=3600",
ETAG -> "xx")
Cookies是一個(gè)特殊格式的HTTP頭部,使用一系列的幫助類使他變得更容易。把Cookies加入到HTTP響應(yīng)中:
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響應(yīng)的字符集
HTTP響應(yīng)默認(rèn)使用utf-8
字符集不僅用來(lái)把文本響應(yīng)轉(zhuǎn)換成對(duì)應(yīng)的字節(jié)流,進(jìn)行網(wǎng)絡(luò)傳輸, 而且用";charset=xxx"來(lái)更新content-type頭部。
通過(guò)play.api.mvc.Codec這個(gè)類,字符集被自動(dòng)處理。在當(dāng)前范圍內(nèi),導(dǎo)入
play.api.mvc.Codec這個(gè)隱式類可以更改字符集,用以下的方式操作:
class Application extends Controller {
implicit val myCustomCharset = Codec.javaSupported("iso-8859-1")
def index = Action {
Ok(<h2>Hello World!</h2>).as(HTML)
}
}
關(guān)于HTML的定義:
def HTML(implicit codec: Codec) = {
"text/html; charset=" + codec.charset
}
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。