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(<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

}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章