Session Struts2首次访问时的非法状态例外

Session Struts2首次访问时的非法状态例外,session,struts2,browser-cache,illegalstateexception,Session,Struts2,Browser Cache,Illegalstateexception,我有一个受保护的页面,在未登录时应该重定向到登录屏幕。问题是,当我试图查看该页面时,它不是重定向到登录,而是崩溃并出现IllegalStateException错误。更重要的是,如果我手动访问它加载的登录页面,然后我尝试再次访问保护页面,它将按预期重定向。这一定是某种会话缓存问题,因为除非重新启动浏览器,否则该问题将不会再次发生。重新启动浏览器后,问题将继续,直到我再次手动访问登录页面。当然,错误报告对于问题的实质来说是非常模糊的 Aug 20, 2013 4:36:40 PM org.apac

我有一个受保护的页面,在未登录时应该重定向到登录屏幕。问题是,当我试图查看该页面时,它不是重定向到登录,而是崩溃并出现IllegalStateException错误。更重要的是,如果我手动访问它加载的登录页面,然后我尝试再次访问保护页面,它将按预期重定向。这一定是某种会话缓存问题,因为除非重新启动浏览器,否则该问题将不会再次发生。重新启动浏览器后,问题将继续,直到我再次手动访问登录页面。当然,错误报告对于问题的实质来说是非常模糊的

Aug 20, 2013 4:36:40 PM org.apache.catalina.core.StandardWrapperValve invoke
SEVERE: Servlet.service() for servlet default threw exception
java.lang.IllegalStateException
at org.apache.catalina.connector.ResponseFacade.sendError(ResponseFacade.java:407)
at org.apache.struts2.dispatcher.Dispatcher.sendError(Dispatcher.java:852)
at org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:534)
at org.apache.struts2.dispatcher.ng.ExecuteOperations.executeAction(ExecuteOperations.java:77)
at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.doFilter(StrutsPrepareAndExecuteFilter.java:91)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.springframework.orm.hibernate3.support.OpenSessionInViewFilter.doFilterInternal(OpenSessionInViewFilter.java:198)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.__invoke(StandardContextValve.java:191)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java)
at org.apache.catalina.core.StandardHostValve.__invoke(StandardHostValve.java:127)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:857)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
at java.lang.Thread.run(Thread.java:662)
我的拦截器,用于验证它们是否已登录,并在必要时重定向。第一个
return BaseAction.Login
按预期的方式点击,当我启用日志记录时,struts2记录器指示将要重定向到viewLogin,但事实并非如此。我只是撞车:

public String intercept(ActionInvocation invocation) throws Exception {
    BaseAction action = (BaseAction)invocation.getAction();
LoginManager loginManager = (LoginManager)action.getSession().get("loginManager");
Boolean loggedIn = false;

    final ActionContext context = invocation.getInvocationContext(); 
    ActionMapping mapping = (ActionMapping)context.get(ServletActionContext.ACTION_MAPPING);


        if(loginManager == null && action.isLoginRequired()) {
            //user is not logged in and login required, redirect them to login module
            return BaseAction.LOGIN;
        } else if(loginManager != null && action.isLoginRequired()) {
            //logged in, make sure they are accessing a valid resource
            String loginKey = action.getSessionLoginVarable(mapping);
            if(loginManager.getLoginPaths().containsKey(loginKey)) {
                return invocation.invoke();
            } else {
                //return to login which will redirect them to appropriate path
                return BaseAction.LOGIN;
            }
        } else {
            //public access to continue with action
            return invocation.invoke();
        }
}
Struts配置文件

<package name="student" namespace="/student" extends="struts-default-custom">
    <default-action-ref name="viewLogin" />
    <global-results>
        <result name="login" type="redirectAction">viewLogin</result>
    </global-results>

    <action name="*Login" method="{1}" class="controller.shared.StudentLogin">
        <interceptor-ref name="noLoginStack"/>

        <result type="redirectAction">viewSearchAdvisors</result>
        <result name="input">/student/student-login.jsp</result>
        <result name="error" type="redirectAction">viewLogin</result>
    </action>

视图登录
查看搜索顾问
/student/student-login.jsp
视图登录
所以,简单地说。在浏览器启动时首次访问此受保护页面时,它会崩溃,而不是重定向到登录。我手动访问登录页面,然后尝试访问受保护的无崩溃页面,它会像预期的那样重定向回登录。它将继续正常工作,直到我重新启动浏览器


有什么想法吗?

这个问题已经解决了。我完全不知道为什么,但当我更改struts xml文件以使用此DTD文件时

而不是


这个问题消失了。我正在抓紧稻草,检查每个配置文件与其他应用程序的配置文件,这些应用程序使用相同的过程,没有问题,我看到了这一点。我决定了到底做了什么,并做出了改变……它起了作用。

这个问题得到了解决。我完全不知道为什么,但当我更改struts xml文件以使用此DTD文件时

而不是


这个问题消失了。我正在抓紧稻草,检查每个配置文件与其他应用程序的配置文件,这些应用程序使用相同的过程,没有问题,我看到了这一点。我决定了他妈的要做什么,并做了更改……它成功了。

你确定这是唯一的堆栈跟踪吗?您发布的消息表明您的代码甚至没有被调用。是的,这是唯一出现在我的IDE控制台以及Tomcat 500错误页面上的stacktrace。我通过调试器跟踪了它,我的代码正在运行。在通过我的拦截器并
返回BaseAction后会出现此异常。登录
检查catalina.out以查看是否还有其他内容。堆栈跟踪根本没有告诉我们问题出在哪里。还有,是什么让LoginManager进入会话,为什么会进入会话?我将查看catalina.out。至于LoginManager,这是在成功登录时设置的。我在这个拦截器中引用它来确定用户是否成功登录,因此如果它不存在或者没有设置正确的参数,我将重定向到login。它包含特定于该用户的各种属性。因此,这自然是唯一一个未登录catalina.out的异常。它有过去的所有其他异常,但我想这一个特别超出了日志文件的范围…你确定这是唯一的堆栈跟踪吗?您发布的消息表明您的代码甚至没有被调用。是的,这是唯一出现在我的IDE控制台以及Tomcat 500错误页面上的stacktrace。我通过调试器跟踪了它,我的代码正在运行。在通过我的拦截器并
返回BaseAction后会出现此异常。登录
检查catalina.out以查看是否还有其他内容。堆栈跟踪根本没有告诉我们问题出在哪里。还有,是什么让LoginManager进入会话,为什么会进入会话?我将查看catalina.out。至于LoginManager,这是在成功登录时设置的。我在这个拦截器中引用它来确定用户是否成功登录,因此如果它不存在或者没有设置正确的参数,我将重定向到login。它包含特定于该用户的各种属性。因此,这自然是唯一一个未登录catalina.out的异常。它有过去的所有其他例外,但我想这一个特别超出了日志文件的范围。。。