0

アプリケーションのセッション タイムアウト処理を 30 分ごとに試行しています。私の仕様:ユーザーセッションが無効になった後にログインに失敗した場合、ログインページにリダイレクトする必要があります。

セッションを無効にするタイムアウト後に、ユーザーはログアウト アクションにリダイレクトされます。

私はプライムフェイスを初めて使用し、これを試しましたが、役に立ちません:

<session-config>
    <session-timeout> 1 </session-timeout>

    <error-page>
        <exception-type>javax.faces.application.ViewExpiredException</exception-type>
        <location>faces/login.xhtml</location>
    </error-page>
</session-config>
4

1 に答える 1

0

最後に、私がp:idleMonitorここで使用しているソリューションを手に入れました。内部的に気を遣ってくれます

<p:idleMonitor timeout="#{login.sessionTimeoutInterval}">
        <p:ajax event="idle" listener="#{login.sessionIdleListener}" /> 
    </p:idleMonitor> 

    <p:confirmDialog  closable="false" id="sessionExpiredDlg" 
                      message="Your session expired."  
                     header="#{msgs['confirmDialog.initiatingDestroyProcess.label']}"
                     severity="alert" widgetVar="sessionExpiredConfirmation" style="z-index: 25000">  

   <p:commandButton id="confirmRouteDel" value="Ok"
                                       oncomplete="sessionExpiredConfirmation.hide()" 
                                       actionListener="#{login.logoutAction}"/>

Java メソッド:

public void sessionIdleListener() {
        RequestContext context = RequestContext.getCurrentInstance();
        context.execute("sessionExpiredConfirmation.show()");
    }

これを一度見てください。

http://www.primefaces.org/showcase/ui/misc/idleMonitor.xhtml

その中に2つの例があります。

于 2013-01-31T14:20:31.900 に答える