1

セッションの有効期限が切れたら、ログイン ページにリダイレクトする必要があります。

HttpSessionListener を使用しています。sessionDestroyed メソッドを呼び出していますが、ログイン ページにリダイレクトできません。

リダイレクト中に Null ポインター例外が発生します

Java クラス

import com.and.web.util.FacesUtils;
import java.io.IOException;
import java.util.Date;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.servlet.http.HttpSession;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;

public class MyHttpSessionListener implements HttpSessionListener {

    public void sessionCreated(HttpSessionEvent se) {
        HttpSession session = se.getSession();
        System.out.print(getTime() + " (session) Created:");
        System.out.println("ID=" + session.getId() + " MaxInactiveInterval="
                + session.getMaxInactiveInterval());
    }

    public void sessionDestroyed(HttpSessionEvent se) {
        HttpSession session = se.getSession();
        session.invalidate();
        try {
            FacesUtils.getExternalContext().redirect("/tnt-ui/");
        } catch (IOException ex) {
            Logger.getLogger(MyHttpSessionListener.class.getName()).log(Level.SEVERE, null, ex);
        }
        // session has been invalidated and all session data
        //(except Id)is no longer available
        System.out.println(getTime() + " (session) Destroyed:ID=" + session.getId());
    }

    private String getTime() {
        return new Date(System.currentTimeMillis()).toString();
    }
}

Web.xml

<listener>
    <listener-class>`com.and.web.bean.MyHttpSessionListener`</listener-class>
</listener>

これを行う方法?解決策を教えてください。

4

1 に答える 1

3
public void sessionDestroyed(HttpSessionEvent se) {
    HttpSession session = se.getSession();
    session.invalidate();
    try {
        FacesUtils.getExternalContext().redirect("/tnt-ui/");

これはうまくいきません。リダイレクトは、リクエスト処理中にのみ発行できます。sessionDestroyed通常はタイムアウト イベントであり、要求スレッドによって呼び出されることはありません。

(たとえば)フィルターを使用して、期限切れのセッションを検出し、リダイレクトすることができます。

于 2013-01-11T13:16:06.897 に答える