Spring MVC 过滤器

最近 Spring—MVC 项目, 定义的过滤器类:

代码如下:

package com.cmcc.soc.aop;

import org.springframework.web.filter.OncePerRequestFilter; // 过滤器类 需要 实现的 每次请求都过滤的类

import javax.servlet.FilterChain; //请求的 处理链
import javax.servlet.ServletException; //servlet 的异常
import javax.servlet.http.HttpServletRequest; //http 的请求 
import javax.servlet.http.HttpServletResponse; //http 的响应
import java.io.IOException; //io 流异常
import java.io.PrintWriter; // 字符输出流

/**
 * Project: soc
 * User: Henry
 * Date: 13-7-26
 * Description:
 * Modify Memo:
 */
public class AuthenticationFilter extends OncePerRequestFilter {//继承一个 每次都过滤的过滤器类
    @Override
    protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws ServletException, IOException {

        // 不过滤的uri
        String[] notFilter = new String[] { "/Login/Login.do","/Home/Index.do"};// 设置不过滤的uri

        // 请求的uri
        String contextpath = request.getContextPath();  //获取上下文的路径
        String spring_uri = request.getRequestURI().replace(contextpath, "");  //获取 请求的  uri

        boolean doFilter = true;// 简写  doFiter 为true 时 会执行下面的

        for (String s : notFilter) { //遍历 不过滤的uri
            if (spring_uri.equals(s)) {  //取过 获取的uri  包含不过滤的 uri  doFiter 返回false
                // 如果uri中包含不过滤的uri,则不进行过滤
                doFilter = false;
                break; //退出 循环
            }
        }

        if (doFilter) {
            Object obj = request.getSession().getAttribute("user");//获取session 中的值
            if (null == obj) {  //如果session中的值是空的话  设置 响应
                // 如果session中不存在登录者实体,则弹出框提示重新登录
                // 设置request和response的字符集,防止乱码
                request.setCharacterEncoding("UTF-8");
                response.setCharacterEncoding("UTF-8");
                PrintWriter out = response.getWriter();// 字符输出流
                String loginPage = "/Login/Login.do";//登录页
                StringBuilder builder = new StringBuilder();

                //javascript
                builder.append("<script type=\"text/javascript\">");
                builder.append("alert('网页过期,请重新登录!');");
                builder.append("window.top.location.href='");// 地址转到
                builder.append(contextpath);//项目 路径
                builder.append(loginPage);//  登录页
                builder.append("';");
                builder.append("</script>");
                out.print(builder.toString()); //输出
            } else {
                // 如果session中存在登录者实体,则继续
                filterChain.doFilter(request, response);
            }
        } else {
            // 如果不执行过滤,则继续
            filterChain.doFilter(request, response);
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring MVC的拦截器是一种应用于请求和响应过程中的过滤器,可以用于对请求进行预处理、对响应进行后处理,以及在请求到达处理程序之前或处理程序返回响应之后执行某些操作。 在Spring MVC中,拦截器是通过实现HandlerInterceptor接口来实现的。该接口定义了三个方法,分别是preHandle()、postHandle()和afterCompletion()。 - preHandle()方法在请求到达处理程序之前执行,可以用于进行身份验证、权限校验等操作,如果该方法返回false,则请求将被拦截并不会到达处理程序。 - postHandle()方法在处理程序完成请求处理后但尚未返回响应时执行,可以用于修改响应或添加一些额外的信息。 - afterCompletion()方法在请求处理完成后执行,无论成功或失败都会执行,可以用于进行资源清理等操作。 要使用拦截器,需要在Spring配置文件中进行配置,并将其注册到DispatcherServlet中。 下面是一个简单的拦截器示例,用于记录请求处理时间: ```java public class TimeInterceptor implements HandlerInterceptor { private static final Logger LOGGER = LoggerFactory.getLogger(TimeInterceptor.class); @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { request.setAttribute("startTime", System.currentTimeMillis()); return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { long startTime = (long) request.getAttribute("startTime"); long endTime = System.currentTimeMillis(); LOGGER.info("Request URL: {} , Time: {}ms", request.getRequestURL(), endTime - startTime); } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { // do nothing } } ``` 在Spring配置文件中进行配置: ```xml <mvc:interceptors> <bean class="com.example.TimeInterceptor" /> </mvc:interceptors> ``` 这样,每次请求处理完成后,日志中就会打印该请求的处理时间,以便进行性能优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值