JavaWeb 中doFilter方法中获取Session对象判断Session中是否存在用户信息
在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"属性也存在,说明用户已经登录,我们就可以继续执行请求,否则就重定向到登录页面
原文地址: https://www.cveoy.top/t/topic/fTxm 著作权归作者所有。请勿转载和采集!