SpringMVC之拦截器的使用方法

springmvc之拦截器

拦截器的概述及其作用:

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

将拦截器按一定的顺序联结成一条链,这条链称为拦截器链(InterceptorChain)。在访问被拦截的方法或字段时,拦截器链中的拦截器就会按其之前定义的顺序被调用。拦截器也是AOP思想的具体实现。

关于interceptor和filter的区别(面试可能会问):

在这里插入图片描述

实现自定义拦截器的开发步骤:

①创建拦截器类实现HandlerInterceptor接口

编写自定义的拦截器:

public class MyInterceptor implements HandlerInterceptor {

    //在目标方法执行之前 执行
    /*
    * 用法解析:
    * 1.如果返回值为true,则放行
    * 应用场景: 用户点击后台管理,在此前用户登录的时候,将用户信息存放到了
    *           session域中,在此进行相关的校验,如果判断有
    *           则返回true,放行。用户成功进入后台
    * 2.如果返回值为false,则对该资源进行相应的拦截
    * 应用场景:比如用户点击后台管理,此前并没有登录,我们可以在session中
    *         检查有没有用户登录的信息,没有则进入后台失败跳转到
    *         登录界面,进行相应的拦截操作
    * */
    @Override
    public boolean preHandle(HttpServletRequest req, HttpServletResponse resp, Object o) throws Exception {

        HttpSession session = req.getSession();

        String user = (String) session.getAttribute("user");

        if(user==null){

            resp.sendRedirect("login.jsp") ;
            return false;
        }

        return true;
    }

    //在目标方法执行之后 视图对象返回之前执行
    /*
    * 可以进行的操作:
    * 1.可以对目标方法中ModelAndView封装的数据进行二次修改
    * 2.可以对目标方法中ModelAndView中的视图进行二次修改,改变跳转的页面
    * */
    @Override
    public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {

    }

    //在流程都执行完毕后 执行
    /*
    * 其中封装了一些异常的信息,可以根据需求进行一些操作
    * */
    @Override
    public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {

    }
}

②配置拦截器

配置:在SpringMVC的配置文件中配置

    <!--配置拦截器-->
    <mvc:interceptors>
        <mvc:interceptor>
            <!--对哪些资源执行拦截操作-->
            <mvc:mapping path="/**"/>
            <!--对哪些资源执行放行操作-->
            <mvc:exclude-mapping path="/demo31"/>
            <bean class="com.duanping.interceptor.MyInterceptor"></bean>
        </mvc:interceptor>
    </mvc:interceptors>


③测试拦截器的拦截效果

制造一种业务场景
编写测试程序测试:

    @RequestMapping("demo29")

    public String  demo29(){

        System.out.println("用户前往购买........");

        return "redirect:demo30";
    }

    @RequestMapping("demo30")
    @ResponseBody
    public void  demo30(){

        System.out.println("用户来到支付页面......");

    }
    @RequestMapping("demo31")
    public String  demo31(HttpServletRequest req){

        System.out.println("正在往session域中存用户登录信息。。。。。。。");

        String user="用户登录信息";

        HttpSession session = req.getSession();

        session.setAttribute("user",user);

        return "redirect:demo30";
    }

<html>
<head>
    <title>Title</title>
</head>
<body>
欢迎来到登录页面》。。。。。
<br>
<br>
<a href="${pageContext.request.contextPath}/demo31">登录</a>
</body>
</html>

测试步骤:

前提:一次会话下

1.第一次访问 http://localhost:8080/demo29

此时session中没有用户信息,拦截器进行拦截

并跳转到登录界面 http://localhost:8080/login.jsp
在这里插入图片描述

2.点击登录(参考上面的代码,了解相关的作用)

此时用户登录成功,我们已经往session域中存放了用户的登录信息

然后成功进入到支付页面

在这里插入图片描述
3.第二次访问 http://localhost:8080/demo29

在当前会话中,session中已经有了用户登录的信息
可以成功直接前往支付页面

在这里插入图片描述

测试完毕。。。。。。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值