因此,我想在播放框架中编写简单的登录逻辑。密码检查看起来像这样
...
.filter(user => BCrypt.checkpw(req.password, user.password))
...
工作正常。但是,如果密码不正确,则会出现异常:
Future.filter predicate is not satisfied
但是,我想抛出自己的异常,所以我做到了:
...
.map(user =>
if (!BCrypt.checkpw(req.password, user.password)) {
throw WrongCredentials()}
else user)
...
哪个可行,但我一直想知道是否有更清洁的方法。
答案 0 :(得分:0)
您可以执行以下操作(来自官方文档):
val purchase: Future[Int] = rateQuote map {
quote => connection.buy(amount, quote)
} recover {
case QuoteChangedException() => 0
}