更改默认的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(<h1>Hello World!</h1>).as("text/html")
或者如下:
val htmlResult2 = Ok(<h1>Hello World!</h1>).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(<h1>Hello World!</h1>).as(HTML)
}
}
关于HTML的定义:
def HTML(implicit codec: Codec) = {
"text/html; charset=" + codec.charset
}