作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有人可以揭露这段代码的神秘色彩,这是Play20框架中zentasks示例的一部分。我很好奇这是如何工作的,因为我是Java的Scala的新手,所以很多事情很难缠住我的头。
def IsAuthenticated(f: => String => Request[AnyContent] => Result) =
Security.Authenticated(username, onUnauthorized) { user =>
Action(request => f(user)(request))
}
最佳答案
您需要对签名进行一些拆分。 f
是一个函数,它接受尚未计算的字符串=> String
并返回另一个接受Request[AnyContent]
并返回结果的函数。Security.Authenticated
调用接受两个参数列表。一种具有username
和onUnauthorized
的代码。第二个函数接受用户并返回一个 Action 。Action.apply
方法接受函数Request[AnyContent] => Result
因此,f以“curried”方式被调用。那就是第一个函数被调用,然后立即使用生成的函数f(user)(request)
。
这是丑陋的(至少,尽我所能)和丑陋的东西:
def isAuthenticated(f: => String => Request[AnyContent] => Result) =
Security.Authenticated(username, onUnauthorized) { user: String =>
Action.apply { request: Request[AnyContent] =>
val hiddenTmp: Request[AnyContent] => Result = f(user)
hiddenTemp.apply(request)
}
}
关于Scala代码揭开神秘面纱,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8597028/
我是一名优秀的程序员,十分优秀!