gpt4 book ai didi

java - Java中的重定向问题(Wicket)

转载 作者:行者123 更新时间:2023-11-30 05:16:10 24 4
gpt4 key购买 nike

我有一个从 WebPage 继承的页面,并受以下类保护:

public final class WiaAuthorizationStrategy implements
IAuthorizationStrategy,
IUnauthorizedComponentInstantiationListener {

private RealmPolicy roleManager;
private static WiaAuthorizationStrategy instance;

private WiaAuthorizationStrategy() {
roleManager = RealmPolicy.getInstance();
}

public static WiaAuthorizationStrategy getInstance() {
if(instance == null)
instance = new WiaAuthorizationStrategy();
return instance;
}

public boolean isInstantiationAuthorized(Class componentClass) {

if (ProtectedPage.class.isAssignableFrom(componentClass)) {
if (WiaSession.get().getUser() == null) {
return false;
}
if(!roleManager.isAuthorized(WiaSession.get().getUser().getRole(), componentClass.getName()))//WiaSession.get().isAuthenticated();
{
WiaSession.get().setAccess(false);
return false;
}
else
return true;
}

return true;
}

public void onUnauthorizedInstantiation(Component component) {
throw new RestartResponseAtInterceptPageException(
Login.class);
}

public boolean isActionAuthorized(Component component, Action action) {
//System.out.println("Name:" + component.getClass().getName() + "\n Action:" + action.getName() + "\nUser:" + WiaSession.get().getUser());
if (action.equals(Component.RENDER)) {
if (roleManager.containClass(component.getClass().getName()))
{
if (WiaSession.get().getUser() != null) {
if(!roleManager.isAuthorized(WiaSession.get().getUser().getRole(), component.getClass().getName()))
{
WiaSession.get().setAccess(false);
return false;
}
return true;
}
return false;
}
}
return true;
}
}

当我进入该页面时,一切正常,但当我按 Ctrl+F5 时,页面重定向到登录页面,这是进入 protected 页面的默认设置。我尝试调试代码,发现 ProtectedPage 类中的 super() 函数执行此操作,并且在调试中我无法输入这部分代码。这个类存在于下面:

public abstract class ProtectedPage extends WebPage {

public ProtectedPage() {

---->>> super (); 验证访问(); }

    protected void verifyAccess() {
// Redirect to Login page on invalid access.
if (!isUserLoggedIn()) {
throw new RestartResponseAtInterceptPageException(Login.class);
}
}

protected boolean isUserLoggedIn() {
return ((WiaSession) getSession()).isAuthenticated();
}
}

我已通过 ---->>> 登录代码进行了签名。谁能帮我解决这个问题吗?

最佳答案

当你安装了 IAuthorizationStrategy 时,不要使用 verifyAccess 之类的东西;后者应该为您完成全部工作。

关于java - Java中的重定向问题(Wicket),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1181268/

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