0

ログインしていないときにログイン画面にリダイレクトすることになっている保護されたページがあります。問題は、そのページを表示しようとすると、ログインにリダイレクトする代わりに、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>

要約するだけです。ブラウザの起動時にこの保護されたページに最初にアクセスすると、ログインにリダイレクトされる代わりにクラッシュします。手動でログインページにアクセスしてから、保護されたページにアクセスしようとすると、クラッシュせずにログインにリダイレクトされます。ブラウザを再起動するまで、正常に動作し続けます。

何か案は??

4

1 に答える 1

3

この問題は解決されました。理由はまったくわかりませんが、struts xml ファイルをこの DTD ファイルを使用するように変更したとき

http://struts.apache.org/dtds/struts-2.3.dtd

それ以外の

http://struts.apache.org/dtds/struts-2.1.dtd

問題はなくなりました。すべての構成ファイルを、同じプロセスを問題なく使用している他のアプリの構成ファイルと比較してチェックするストローを把握していて、これを見ました。私は一体何を決定し、変更を加えました...そしてそれは機能します。

于 2013-08-22T01:01:39.143 に答える