【问题标题】:How to invalidate session when client's IP address changes客户端IP地址更改时如何使会话无效
【发布时间】:2017-10-04 06:07:09
【问题描述】:

如果用户的 IP 地址发生更改,我会尝试使用户会话无效(我想强制用户在整个会话期间保持相同的 IP 地址,或者他们需要重新进行身份验证)。我会假设 Spring Security 内置了一个功能来实现这一点,但我似乎找不到它。

实现这个要求的最优雅的方式是什么(最好通过 Spring Security 的配置)?

【问题讨论】:

    标签: java spring-mvc session spring-security


    【解决方案1】:

    我在 Spring Security 中找不到任何将会话绑定到 IP 的内置功能,但使用自定义过滤器很容易实现:

    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) {
        boolean chainCompleted = implementEnforcement(request, response);
        if (!chainCompleted) {
            filterChain.doFilter(request, response);
        }
    }
    
    private boolean implementEnforcement(HttpServletRequest request, HttpServletResponse response) throws IOException {
        final String key = "enforcement.ip";
        HttpSession session = request.getSession(false);
        if (session != null) {
            // we have a session
            String ip = request.getRemoteAddr();
            String ipInSession = session.getAttribute(key);
            if (ipInSession == null) {
                session.setAttribute(key, ip);
            } else {
                if (!ipInSession.equals(ip)) {
                    // JSESSIONID is the same, but IP has changed
                    // invalidate the session because there is a probability that it is
                    // a session hijack
                    session.invalidate();
                    // a redirection to some page (probably to context root) may be added here
                    return true;
                }
            }
        }
        return false;
    }
    

    它会记住用户的 IP 地址,然后将当前 IP 与记住的 IP 进行比较:如果不同,则销毁会话。

    【讨论】:

    猜你喜欢
    • 2011-12-03
    • 2010-11-03
    • 1970-01-01
    • 2015-02-28
    • 2014-10-16
    • 2016-09-25
    • 2018-04-27
    • 1970-01-01
    相关资源
    最近更新 更多