session和flash scope 的區別
如果需要通過多個HTTP請求傳輸數據,那麼就要用到session和flash
scope。在session中存儲的,整個會話過程都有效,在flash scope
中存儲的,只是對下一個請求有效。服務器不存儲session和flash
scope中的數據,它們只是被傳遞給了下一個請求,使用Cookies機制。這就意味着你只能存儲字符串類型,而且大小有限,最多4KB。Cookies的默認名字是PLAY_SESSION,通過application.conf中的session.cookieName可以修改。
cookie的數據被標記了一個密鑰,因此客戶端無法修改Cookies的數據,否則數據會被判無效。
Play Session不被用來作爲緩存,如果需要緩存一些和session相關的數據,就要使用play內置的緩存機制,在用戶的session中存儲一個unique ID來保持和特定用戶的關聯。
Session默認沒有失效時間,除非用戶關掉瀏覽器。如果需要設定失效時間,就要在用戶session中存儲一個時間戳,不管application是否需要。可以在application.conf中通過play.http.session.maxAge設置最長的失效時間,但也不能防止***恢復過了有效期的Cookies。
在Session中存儲數據
由於Session只是Cookie,同時也只是一個HTTP的頭部,你可以用與處理請求結果相同的方式處理session的數據:
Ok("Welcome!").withSession( "connected" -> "[email protected]")
在已有的session中添加一個元素,並且生成新session的方式如下:
Ok("Hello World!").withSession( request.session + ("saidHello" -> "yes"))
刪除session中的元素也是用類似的方式:
Ok("Theme reset!").withSession( request.session - "theme")
讀取Session的值
從HTTP請求中搜索Session:
def index = Action { request => request.session.get("connected").map { user => Ok("Hello " + user) }.getOrElse { Unauthorized("Oops, you are not connected") }}
丟棄整個Session
以下操作可以丟棄整個Session:
Ok("Bye").withNewSession
Flash Scope
Flash Scope的工作方式和Session有兩點不同:
數據只在一個請求中保留,另一點是Flash cookie沒有標記,用戶可以修改它。
Flash scope只能在沒有Ajax的applications中傳輸success/error信息,由於數據只在一個請求中並且在複雜web應用中不能保證請求的順序,因此它受到競爭條件的約束。
使用Flash scope的例子如下:
def index = Action { implicit request => Ok { request.flash.get("success").getOrElse("Welcome!") }}def save = Action { Redirect("/home").flashing( "success" -> "The item has been created")}
在view中搜索Flash scope的值,並且添加隱式的Flash參數,具體操作如下:
@()(implicit flash: Flash)[email protected]("success").getOrElse("Welcome!")...
然後在Action中隱式指定implicit request =>,通過如下方式:
def index = Action { implicit request => Ok(views.html.index())}
基於隱式的請求,一個隱式的Flash會被提供給view。
如果報瞭如下錯誤:
‘could not find implicit value for parameter flash: play.api.mvc.Flash’
那說明你的Action在範圍內沒有隱式的請求。