SpringMVC--拦截器(九)

一、拦截器

  Spring Web MVC 的处理器拦截器类似于Servlet 开发中的过滤器Filter,用于对处理器进行预处理和后处理。

二、定义拦截器

实现HandlerInterceptor接口

public class LogInterceptor implements HandlerInterceptor{

    /**
     * controller执行后且视图返回后调用此方法
     * 这里可得到执行controller时的异常信息
     * 这里可记录操作日志,资源清理等
     */
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object arg2, Exception arg3)
            throws Exception {
        
    }
    /**
     * controller执行后但未返回视图前调用此方法
     * 这里可在返回用户前对模型数据进行加工处理,比如这里加入公用信息以便页面显示
     */
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object arg2, ModelAndView arg3)
            throws Exception {
        
    }
    /**
     * controller执行前调用此方法
     * 返回true表示继续执行,返回false中止执行
     * 这里可以加入登录校验、权限拦截等
     */
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object arg2) throws Exception {  
        return false;
    }
}

三、拦截器配置

  1. 针对某种mapping配置拦截器
<bean
    class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping">
        <property name="interceptors">
            <list>
                <ref bean="logInterceptor" />
            </list>
        </property>
    </bean>
    <bean id="logInterceptor" class="com.neuedu.interceptor.LogInterceptor" />

  1. mapping配置全局拦截器
<!--拦截器 -->
<mvc:interceptors>
    <!--多个拦截器,顺序执行 -->
    <mvc:interceptor>
        <mvc:mapping path="/**"/>
        <bean class="com.neuedu.interceptor.HandlerInterceptorLog"></bean>
    </mvc:interceptor>
    <mvc:interceptor>
        <mvc:mapping path="/**"/>
        <bean class="com.neuedu.interceptor.HandlerInterceptorLogin"></bean>
    </mvc:interceptor>
</mvc:interceptors>

  1. 日志拦截器
public class HandlerInterceptorLog implements HandlerInterceptor{
    public void afterCompletion(HttpServletRequest request,
                                HttpServletResponse response, Object arg2, Exception arg3)
            throws Exception {
        System.out.println("日志拦截器后……");
    }
    public void postHandle(HttpServletRequest request,
                           HttpServletResponse response, Object arg2, ModelAndView arg3)
            throws Exception {
        System.out.println("控制器已执行,但视图未返回……");
    }
    public boolean preHandle(HttpServletRequest request,
                             HttpServletResponse response, Object arg2) throws Exception {
        System.out.println("日志拦截器前……");
        return true;
    }
}
  1. 登录拦截器

1) 用户登陆 controller

// 登陆提交
// userid:用户账号,pwd:密码
    @RequestMapping("/login")
    public String login(HttpSession session, String userid, String
            pwd) throws Exception {
// 向session记录用户身份信息
        session.setAttribute("activeUser", userid);
        return "redirect:order/itemsList";
    }
    // 退出
    @RequestMapping("/logout")
    public String logout(HttpSession session) throws Exception {
// session过期
        session.invalidate();
        return "redirect:login";
    }
  1. 拦截器
public class LoginInterceptor implements HandlerInterceptor{
//  进入 Handler方法之前执行
//  用于身份认证、身份授权
//  比如身份认证,如果认证通过表示当前用户没有登陆,需要此方法拦截不再向下执行
    @Override
    public boolean preHandle(HttpServletRequest request,
                             HttpServletResponse response, Object handler) throws
            Exception {
//  获取请求的url
        String url = request.getRequestURI();
//  判断url是否是公开 地址(实际使用时将公开 地址配置配置文件中)
//  这里公开地址是登陆提交的地址
        if(url.indexOf("login")>=0){
//  如果进行登陆提交,放行
            return true;
        }
//  判断session
        HttpSession session = request.getSession();
//  从session中取出用户身份信息
        String username = (String)
                session.getAttribute("username");
        if(username != null){
//  身份存在,放行
            return true;
        }
//  执行这里表示用户身份需要认证,跳转登陆页面
        request.getRequestDispatcher("/WEBINF/views/login.jsp").forward(request, response);
//  return false表示拦截,不向下执行
//  return true表示放行
        return false;
    }
//  进入Handler方法之后,返回modelAndView之前执行
//  应用场景从modelAndView出发:将公用的模型数据(比如菜单导航)在这里传到
    视图,也可以在这里统一指定视图
    @Override
    public void postHandle(HttpServletRequest request,
                           HttpServletResponse response, Object handler,
                           ModelAndView modelAndView) throws Exception {
        System.out.println("返回数据……");
    }
    //  执行Handler完成执行此方法
    //  应用场景:统一异常处理,统一日志处理
    @Override
    public void afterCompletion(HttpServletRequest request,
                                HttpServletResponse response, Object handler, Exception
                                        ex)
            throws Exception {
        System.out.println("日志统一处理");
    }
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一、引言 本来想记录一下关于用户登陆和登陆之后的权限管理、菜单管理的问题,想到解决这个问题用到Intercepto...
    青青子衿zq阅读 1,567评论 1 1
  • IOC 控制反转容器控制程序对象之间的关系,而不是传统实现中,有程序代码之间控制,又名依赖注入。All 类的创建,...
    irckwk1阅读 987评论 0 0
  • 16. Web MVC 框架 16.1 Spring Web MVC 框架介绍 Spring Web 模型-视图-...
    此鱼不得水阅读 1,079评论 0 4
  • 对于java中的思考的方向,1必须要看前端的页面,对于前端的页面基本的逻辑,如果能理解最好,不理解也要知道几点。 ...
    神尤鲁道夫阅读 842评论 0 0
  • Springmvc的处理器拦截器类似于Servlet 开发中的过滤器Filter,用于对处理器进行预处理和后处理。...
    Cherry300阅读 472评论 0 1