- import java.io.IOException;
- import javax.servlet.Filter;
- import javax.servlet.FilterChain;
- import javax.servlet.FilterConfig;
- import javax.servlet.ServletException;
- import javax.servlet.ServletRequest;
- import javax.servlet.ServletResponse;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import javax.servlet.http.HttpSession;
- /**
- * 设置字符集、过滤未登录的非法请求
- */
- public class UserLoginFilter implements Filter {
- protected String encoding = null;
- protected FilterConfig filterConfig = null;
- protected boolean ignore = false;
- protected String forwardPath = null;
- public void destroy() {
- this.encoding = null;
- this.filterConfig = null;
- }
- public void doFilter(ServletRequest request, ServletResponse response,
- FilterChain chain) throws IOException, ServletException {
- // 设置编码方式,web.xml里面有filter参数的初始化设置
- if (ignore || (request.getCharacterEncoding() == null)) {
- String encoding = selectEncoding(request);
- if (encoding != null)
- request.setCharacterEncoding(encoding);
- }
- HttpServletRequest httpServletRequest = (HttpServletRequest) request;
- HttpServletResponse httpServletResponse = (HttpServletResponse) response;
- String requesturi = httpServletRequest.getRequestURI();
- // 通过检查session中的变量,过虑请求,最好把username提取出来当常量
- HttpSession session = httpServletRequest.getSession();
- Object currentUser = session.getAttribute("username");
- // 当前会话用户为空而且不是请求登录,退出登录,欢迎页面和根目录则退回到应用的根目录
- if (currentUser == null
- && !requesturi.endsWith("/login.action")
- && !requesturi.endsWith("/logout.action")
- && !requesturi.endsWith("/index.jsp")
- && !requesturi.endsWith(httpServletRequest.getContextPath()
- + "/")) {
- httpServletResponse.sendRedirect(httpServletRequest
- .getContextPath()
- + "/");
- return;
- }
- chain.doFilter(request, response);
- }
- public void init(FilterConfig filterConfig) throws ServletException {
- this.filterConfig = filterConfig;
- this.encoding = filterConfig.getInitParameter("encoding");
- this.forwardPath = filterConfig.getInitParameter("forwardpath");
- String value = filterConfig.getInitParameter("ignore");
- if (value == null)
- this.ignore = true;
- else if (value.equalsIgnoreCase("true"))
- this.ignore = true;
- else if (value.equalsIgnoreCase("yes"))
- this.ignore = true;
- else
- this.ignore = false;
- }
- protected String selectEncoding(ServletRequest request) {
- return (this.encoding);
- }
- }
- web.xml中的设置
- <filter>
- <filter-name>Login Filter</filter-name>
- <filter-class>
- 你的包名(自己改一下).UserLoginFilter
- </filter-class>
- <init-param>
- <param-name>encoding</param-name>
- <param-value>GBK</param-value>
- </init-param>
- <init-param>
- <param-name>ignore</param-name>
- <param-value>false</param-value>
- </init-param>
- <init-param>
- <param-name>forwardpath</param-name>
- <param-value>index.jsp</param-value>
- </init-param>
- </filter>
- <filter-mapping>
- <filter-name>Login Filter</filter-name>
- <url-pattern>/*</url-pattern>
- </filter-mapping>
filter权限
最新推荐文章于 2021-11-14 19:54:13 发布
