在JavaWeb中,可以通过ServletRequest对象获取Session对象,然后判断Session中是否存在用户信息。具体实现代码如下:

public class LoginFilter implements Filter {
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
        HttpServletRequest req = (HttpServletRequest) request;
        HttpServletResponse resp = (HttpServletResponse) response;
        HttpSession session = req.getSession(false); // false表示不创建新的Session对象
        if (session != null && session.getAttribute("user") != null) {
            // 用户已经登录,继续执行请求
            chain.doFilter(request, response);
        } else {
            // 用户未登录,重定向到登录页面
            resp.sendRedirect(req.getContextPath() + "/login.jsp");
        }
    }
}

在上面的代码中,我们首先通过ServletRequest的强制类型转换获取到HttpServletRequest对象,然后调用其getSession(false)方法获取Session对象。如果Session对象存在且其中的"user"属性也存在,说明用户已经登录,我们就可以继续执行请求,否则就重定向到登录页面

JavaWeb 中doFilter方法中获取Session对象判断Session中是否存在用户信息

原文地址: https://www.cveoy.top/t/topic/fTxm 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录