拦截器

全局拦截器

在springmvc.xml文件中配置

在这里插入图片描述

/**的意思是所有文件夹及里面的子文件夹
/*是所有文件夹,不含子文件夹
/是web项目的根目录

创建两个拦截器
在这里插入图片描述
在这里插入图片描述

那么这两个类文件怎么知道是拦截器啊
所以这两个类需要实现拦截器的接口
Interceptor1 implements HandlerInterceptor

拦截器有三个方法
在这里插入图片描述

一个是最先执行的,一个是最后执行,还有个在二者之间执行

通常我们使用public boolean preHandle
就可以了,在最早执行的时候我们判断用户登录是否正确

测试
测试场景:第一个拦截器放行,第二个拦截器也放行:
当改为true就为放行,当用户输入用户名密码不对就不放行。

在这里插入图片描述
运行

在这里插入图片描述

第一个拦截器放行,第二个不放行:

Springmvc官方文档规定:凡是preHandle返回true,afterCompletion必须执行。

这是第一个拦截器Interceptor1。。。preHandle
这是第二个拦截器Interceptor2。。。preHandle
这是第一个拦截器Interceptor1。。。afterCompletion
在这里插入图片描述

拦截指定路由

在这里插入图片描述

        <mvc:exclude-mapping path="/login.html" />
        <mvc:exclude-mapping path="/account/login.do" />
        <mvc:exclude-mapping path="/account/regist.do" />

设置拦截所有,但除了edit.do请求

在这里插入图片描述
在这里插入图片描述

上面设置之后
在浏览器中输入下面,则无法访问,因为被拦截了
http://localhost:8080/items/list.do
但访问下面则会成功,因为排除拦截了
http://localhost:8080/items/edit.do

实战

@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object o) throws Exception {

System.out.println("这是第一个拦截器Interceptor1。。。preHandle");

// 打印请求url地址
System.out.println("===="+request.getServletPath());

//1、请求到登录页面 放行
if(request.getServletPath().startsWith("/user/list.do")) {

    System.out.println("通行");
    return true;
}

//3、如果用户已经登录 放行
if(request.getSession().getAttribute("username") != null) {
    //更好的实现方式的使用cookie
    return true;
}

System.out.println("----"+request.getParameter("id")); // 打印请求参数值
System.out.println("----"+request.getMethod()); // 打印GET

//重定向到登录页面
response.sendRedirect(request.getContextPath() + "/user/list.do");


return true;

}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值