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

今天配置了一个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
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值