如何在Play Framework中处理会话超时或到期?

时间:2014-04-25 02:59:22

标签: java playframework playframework-2.0 playframework-2.2

我想知道用户的会话是否已在服务器端过期,并在发生这种情况时执行某些操作。我该怎么做?

我正在使用Java和Play框架2.2.1。

2 个答案:

答案 0 :(得分:11)

使用Play built-in authentication时,在每个经过身份验证的请求中,在会话中存储时间戳并更新过期。

然后,在身份验证器中,验证会话到期。

文章How to implement a Session Timeout in 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

答案 1 :(得分:0)

会话超时

  • 会话超时配置项session.maxAge,曾经是一个整数,定义为秒。现在它是一个持续时间,因此可以指定1h或30m之类的值。不幸的是,如果没有时间单位指定的默认单位是毫秒,这意味着配置值3600以前被视为一小时,但现在被视为3.6秒。您需要更新配置以添加时间单位。

See here