Scala下Play框架学习笔记(Manipulating Results)

更改默认的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

}