Как обрабатывать тайм-аут сеанса или истечение срока действия в Play Framework?

Я хочу знать, истек ли сеанс пользователя на стороне сервера и выполнить что-то, когда это произойдет. Как мне это сделать?

Я использую Java и Play framework 2.2.1.

2 ответов


при использовании игры встроенная проверка подлинности, при каждом аутентифицированном запросе храните метку времени в сеансе с обновленным сроком действия.

затем в аутентификаторе проверьте срок действия сеанса.

статьи как реализовать тайм-аут сеанса в Play Framework 2 предлагает такой пример:

public class Secured extends Security.Authenticator {

    public static final String UNAUTHENTICATED = "unauthenticated";

    public static User getLoggedInUser() {
        if (session("userId") == null)
            return null;
        return User.findById(Long.parseLong(session("userId")));
    }

    public static String getLoggedInUsername() {
        if (session("userId") == null)
            return null;
        return User.findById(Long.parseLong(session("userId"))).getUsername();
    }


    @Override
    public String getUsername(Http.Context ctx) {

        // see if user is logged in
        if (session("userId") == null)
            return null;

        // see if the session is expired
        String previousTick = session("userTime");
        if (previousTick != null && !previousTick.equals("")) {
            long previousT = Long.valueOf(previousTick);
            long currentT = new Date().getTime();
            long timeout = Long.valueOf(Play.application().configuration().getString("sessionTimeout")) * 1000 * 60;
            if ((currentT - previousT) > timeout) {
                // session expired
                session().clear();
                return null;
            } 
        }

        // update time in session
        String tickString = Long.toString(new Date().getTime());
        session("userTime", tickString);

        return User.findById(Long.parseLong(session("userId"))).getUsername();
    }
}

для этого требуется sessionTimeout значение в минутах в файле конфигурации приложения (application.conf).


сессия тайм-ауты

  • элемент конфигурации тайм-аута сеанса, сеанс.maxAge, используемый как целое число, определяется как в секундах. Теперь это продолжительность, поэтому ее можно указать со значениями, такими как 1h или 30m. К сожалению, единица по умолчанию, если она указана без единицы времени, - миллисекунды, что означает, что значение конфигурации 3600 ранее рассматривалось как один час, но теперь рассматривается как 3,6 секунды. Вам нужно будет обновить конфигурацию, чтобы добавить время блок.

посмотреть здесь