在我的 play framework 2 应用程序中,我想要一条日志消息,其中包含请求、响应和有关响应的一些详细信息 - 例如从外部网络调用返回的搜索结果的数量。
我现在拥有的是这样的过滤器:
object AccessLog extends Filter {
import play.api.mvc._
import play.api.libs.concurrent.Execution.Implicits._
def apply(next: RequestHeader => Future[SimpleResult])(request: RequestHeader): Future[SimpleResult] = {
val result = next(request)
result map { r =>
play.Logger.info(s"Request: ${request.uri} - Response: ${r.header.status}")
}
result
}
}
在记录时,我已经将我的类转换为 json,因此将 json 解析回对象似乎很浪费,因此我可以记录有关它的信息。
是否有可能在请求管道中更早地计算搜索结果的数量,可能放入字典中,并在我在此处记录消息时将它们拉出?
我在看 flash,但不希望以 cookie 的形式发送这些值。也许我可以改为清除闪光灯。如果有更合适的方法,我希望看到。
这是不涉及用户帐户或 session 的只读 API 的一部分。
最佳答案
您可以尝试使用 play.api.cache.Cache
object如果你能想出一个可重现的唯一请求标识符。记录请求后,您可以将其从 Cache
中删除。
关于scala - Play Framework - 存储有关当前请求的信息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20746597/