gpt4 book ai didi

java - 检查从 Play 中的模块导入的所有 URI 的权限

转载 作者:行者123 更新时间:2023-12-01 12:21:54 25 4
gpt4 key购买 nike

我正在用 Java 编写 Play 2.3.2 应用程序。我使用的模块有我的应用程序需要的一些路由。在我的路由文件中,我将它们包含在以下语句中:

->     /recommendation/       recommendationsystem.Routes

我需要检查以 /recommendation 开头的所有 URI 的权限。如果用户通过身份验证,则执行请求,否则将其重定向到主页。

我已经有一个注释来实现检查权限的操作。

我怎样才能在 Play 中做到这一点?

提前致谢。

最佳答案

你可能 intercept Global 类中的所有请求,并检查特定资源是否需要身份验证。

import play.GlobalSettings;
import play.libs.F;
import play.mvc.Action;
import play.mvc.Http;
import play.mvc.Result;

import java.lang.reflect.Method;

public class Global extends GlobalSettings {

@Override
public Action onRequest(Http.Request request, Method actionMethod) {
if (request.path().startsWith("/recommendation") && isNotAuthenticated()) {
return new Action.Simple() {
@Override
public F.Promise<Result> call(Http.Context context) throws Throwable {
return F.Promise.pure(redirect("/"));
}
};
}
return super.onRequest(request, actionMethod);
}

private boolean isNotAuthenticated() {
// put your authentication check logic here
return true;
}

}

关于java - 检查从 Play 中的模块导入的所有 URI 的权限,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26607884/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com