Spring 拦截器的配置及 filter 的写法

来源:互联网 发布:广联达bim软件价格 编辑:程序博客网 时间:2024/05/16 02:52

今天配置了一个Spring 的拦截器,主要是为了在浏览器访问一部分页面的时候,如果没有对应的session,则返回验证页面。

1、首先,在web.xml 文件里面添加以下配置。

<filter-name>jspFilter</filter-name>     <filter-class>com.util.sms.JspFilter</filter-class> //这里指拦截器所在的位置    <init-param>  <param-name>encoding</param-name>  <param-value>UTF-8</param-value>  //设置拦截器返回的编码  </init-param>    </filter>     <filter-mapping>         <filter-name>jspFilter</filter-name>         <url-pattern>/helpfile/*</url-pattern>  //这里设置的意思是:在进行http 请求的时候,链接只要是访问包含/helpfile的,都会进入拦截器    </filter-mapping> 
2、JspFilter  拦截器方法 实例

package com.util.sms;import java.io.IOException;import java.io.PrintWriter;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 JspFilter implements Filter{private static String encoding;private static final String DEFAULT_CHARSET="UTF-8";public JspFilter() {}    public void destroy() {}    @Override    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {    // TODO Auto-generated method stub          HttpServletRequest request = (HttpServletRequest) req;          HttpServletResponse response = (HttpServletResponse) res;          HttpSession session = request.getSession();          System.out.println("过滤器设置字符编码"+encoding);        request.setCharacterEncoding(encoding);        // 如果session不为空,则可以浏览其他页面          String url = request.getServletPath();          System.out.println(url);          //这里判断目录,后缀名,当然也可以写在web.xml中,用url-pattern进行拦截映射          if ((!request.getServletPath().equals("/helpfile"))) {              System.out.println(request.getServletPath());             //session.getAttribute("userInfo") == null            if (null == request.getSession().getAttribute("tUser")) {                  session.invalidate();                  response.setContentType("text/html;charset=gb2312");                  PrintWriter out = response.getWriter();                  out.println("<script language='javascript' type='text/javascript'>");                  out.println("alert('请验证您的手机号码之后,进行查看!');window.location.href='" + request.getContextPath() + "/help.jsp'");                  out.println("</script>");              } else {                  chain.doFilter(request, response);              }          } else {              chain.doFilter(request, response);          }     }    /**     * @see Filter#init(FilterConfig)     */    public void init(FilterConfig fConfig) throws ServletException {    System.out.println("过滤器设置字符编码sssssssssssssss");    encoding = fConfig.getInitParameter("encoding");        }        }

以上代码段中主要的拦截部分是在红色代码部分,实现的逻辑主要是在不存在session的时候,则返回help.jsp 页面。

配置完成之后,访问链接中包含 /helpfile 的链接的时候,就会进入拦截器。

仅仅是本人做为简单的记录,欢迎大家提意见。

0 0
原创粉丝点击