我正在阅读 James Ward 关于如何使用 authToken ( https://github.com/jamesward/play-rest-security ) 为 API 端点设置一些基本安全性的代码。
有一个 SecurityController
扩展 Action.Simple
的类.其中,有一个 call()
充当实际 http 调用和 Controller 之间代理的方法。我遇到的问题是,显然这个方法的返回类型在 Play Framework 2.2 版中发生了变化,现在返回 Promise<SimpleResult>
而不是 Promise
.
这是无法编译的有问题的方法,因为当我尝试 return unauthorized("unauthorized");
时存在类型不匹配
public Promise<play.mvc.SimpleResult> call(Http.Context ctx) throws Throwable {
User user = null;
String[] authTokenHeaderValues = ctx.request().headers().get(AUTH_TOKEN_HEADER);
if ((authTokenHeaderValues != null) && (authTokenHeaderValues.length == 1) && (authTokenHeaderValues[0] != null)) {
user = models.User.findByAuthToken(authTokenHeaderValues[0]);
if (user != null) {
ctx.args.put("user", user);
return delegate.call(ctx);
}
}
return unauthorized("unauthorized"); // type mismatch here
}
任何想法如何使此代码在 Play 2.2 中工作?谢谢
最佳答案
我对 Play 的 Java API 不太熟悉,但它看起来像 unauthorized()
返回 SimpleResult
.
您需要一个 Promise<SimpleResult>
,这(通过对 this question 的回答)似乎可以通过以下方式获得:
return F.Promise.pure((SimpleResult) unauthorized("unauthorized"));
关于playframework - 如何在 Play Framework 2.2 中创建 Action ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20084064/