加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

Scala代码神秘化

发布时间:2020-12-16 19:08:20 所属栏目:安全 来源:网络整理
导读:有人可以将此代码揭秘,这是Play20框架中zentask示例的一部分.我很好奇这是如何工作的,我认为我是 Java的新来的Scala,所以很多东西都很难包围我的头. def IsAuthenticated(f: = String = Request[AnyContent] = Result) = Security.Authenticated(username,on
有人可以将此代码揭秘,这是Play20框架中zentask示例的一部分.我很好奇这是如何工作的,我认为我是 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调用接受两个参数列表.一个有用户名和未授权的.第二个接收用户并返回动作的功能.

Action.apply方法接受一个函数Request [AnyContent] =>结果

所以,f被叫做“咖喱”的方式.这是第一个函数被调用,然后生成的函数立即使用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.基本上,功能做了大量的功能组合.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读