SpringMVC-拦截器

1、概述

SpringMVC的处理器拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理。也可以自己定义

过滤器与拦截器的区别:拦截器是AOP思想的具体应用

过滤器:

  • servlet规范中的一部分,任何java web工程都可以使用
  • 在url-pattern中配置了/*之后,可以对所有要访问的资源进行拦截

拦截器:

  • 拦截器是SpringMVC框架自己的,只有使用了SpringMVC框架的工程才能使用
  • 拦截器(Interceptor)是一种动态拦截Controller方法调用的对象,如果访问的是jsp、html、css、image、js是不会被拦截的

2、自定义拦截器

自定义一个拦截器,必须要实现HandlerInterceptor接口

当单个拦截器的时候,正常执行:preHandle、postHandle、afterCompletion
当多个拦截器的时候,没有异常情况下:preHandle1、preHandle2、postHandle2、postHandle1、afterCompletion2、afterCompletion1
                    有异常情况下:preHandle1、preHandle2、没有postHandler、afterCompletion2、afterCompletion1

代码实现

  • 拦截器1
public class Interceptor1 implements HandlerInterceptor {
    //判断账号密码
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
            throws Exception {
        System.out.println("Interceptor1 在handler之前执行 preHandle");
        //对拦截的请求进行放行处理
        return true;
    }

    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
                           ModelAndView modelAndView) throws Exception {
        System.out.println("Interceptor1 在handler之后执行 postHandle,但是在视图渲染之前");
    }

    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
            throws Exception {
        System.out.println("Interceptor1 在视图渲染之后执行 afterCompletion");
    }
}
  • 拦截器2
public class Interceptor2 implements HandlerInterceptor {
    //判断账号密码
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
            throws Exception {
        System.out.println("Interceptor2 在handler之前执行 preHandle");
        //对拦截的请求进行放行处理
        return true;
    }

    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
                           ModelAndView modelAndView) throws Exception {
        System.out.println("Interceptor2 在handler之后执行 postHandle,但是在视图渲染之前");
    }

    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
            throws Exception {
        System.out.println("Interceptor2 在视图渲染之后执行 afterCompletion");
    }
}
  • 配置spring-mvc.xml配置文件
<!--配置拦截器-->
<mvc:interceptors>

    <!--配置多个拦截器-->
    <mvc:interceptor>
        <!-- 配置拦截器作用的路径
            /**:包括这个请求下面的所有的请求
         -->
        <mvc:mapping path="/**"/>
        <!-- 定义在 <mvc:interceptor>下面的表示匹配指定路径的请求才进行拦截 -->
        <bean class="com.k2.拦截器.interceptor.Interceptor1"></bean>
    </mvc:interceptor>

    <mvc:interceptor>
        <!--配置局部单个拦截器-->
        <mvc:mapping path="/demo1"/>
        <bean class="com.k2.拦截器.interceptor.Interceptor2"></bean>
    </mvc:interceptor>

</mvc:interceptors>
  • 编写Controller
@Controller
public class DemoController {

    @RequestMapping("/demo1")
    public String demo1(){
        System.out.println("demo1 running---------");
        return "pages/success";
    }

    @RequestMapping("/demo2")
    public String demo2(){
        System.out.println("demo2 running---------");
        return "pages/success";
    }
}
  • 执行结果
    在这里插入图片描述

3、登录验证

  • 编写pojo类
@Data
public class User {
    private String username;
    private String password;
}
  • 自定义拦截器
public class LoginInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        // 针对登录和跳转到登录页面的请求进行放行
        // 获取请求url
        String requestURI = request.getRequestURI();
        // url除了login.jsp登录页面可以公开访问的,其它的不可以
        // requestURI.indexOf("/toLogin"):判断url中的字段中有没有/toLogin,
        if (requestURI.indexOf("/toLogin") > -1 || requestURI.contains("/login")) {
            // 直接放行
            return true;
        }

        // 其它请求需要做登录权限拦截判断
        // 获取session
        HttpSession session = request.getSession();
        // 获取user数据
        User user = (User) session.getAttribute("user");
        System.out.println(user);
        // 判断session中是否有用户数据,如果有返回true
        if (user!=null){
            return true;
        }

        // 不符合条件的给出提示信息,并转发到登录页面
        request.setAttribute("msg","您没有登录,请先登录");
        // 视图解析器不生效,在这用的是原生java-web(servlet)的转发技术
        request.getRequestDispatcher("/WEB-INF/filter/login.jsp").forward(request,response);

        return false;
    }
}
  • 配置mvc配置文件
<mvc:interceptors>
    <!--配置单个拦截器:使用bean直接定义在<mvc:interceptors>下面的拦截器所有请求(单个) -->
    <!--模拟登录页面配置-->
	<bean class="com.k2.拦截器.interceptor.LoginInterceptor"></bean>
</mvc:interceptors>
  • 编写Controller类
@Controller
public class UserController {

    @RequestMapping("/main")
    public String main() {
        return "filter/main";
    }

    @RequestMapping("/toLogin")
    public String toLogin() {
        return "filter/login";
    }

    @RequestMapping("/orderInfo")
    public String toOrderInfo() {
        return "filter/orderInfo";
    }

    /**
     * @param user
     * @param model:model来传递信息
     * @param session:session存放数据
     * @return
     */
    @RequestMapping("/login")
    public String login(User user, Model model, HttpSession session) {
        // 判断用户名密码
        String username = user.getUsername();
        String password = user.getPassword();
        if (username != null && "张三".equals(username) && password != null && "123".equals(password)) {
            // 登录成功,跳转到首页,并且保存用户信息
            session.setAttribute("user", user);
            return "redirect:main";
        } else {
            // 登录失败,给出登录失败的信息,跳转到登录页面
            model.addAttribute("msg", "用户名或密码错误");
            return "filter/login";
        }
    }

    @RequestMapping("/exit")
    public String exit(HttpSession session) {
        // 清空session
//        session.invalidate();
        // 移除session
        session.removeAttribute("user");
        return "redirect:toLogin";
    }
}
  • 编写jsp页面

login.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>用户登录</title>
</head>
<body>
<form action="${pageContext.request.contextPath}/login" method="post">
    <div>${msg}</div>
    用户名:<input type="text" name="username"><br/>
    密码:<input type="password" name="password"><br/>
    <input type="submit" value="登录">
</form>
</body>
</html>

main.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>后台系统</title>
</head>
<body>
<li>您好:${user.username}</li>
<li><a href="${pageContext.request.contextPath}/exit">退出</a></li>
<li><a href="${pageContext.request.contextPath}/orderInfo">订单页面</a></li>
</body>
</html>

orderInfo.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>订单信息</title>
</head>
<body>
您好:${user.username}
<a href="${pageContext.request.contextPath}/exit">退出</a>
<h2>订单页面</h2>
</body>
</html>
  • 验证结果
    在这里插入图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring MVC 中配置拦截器可以通过实现 `HandlerInterceptor` 接口来创建自定义的拦截器。下面是配置拦截器的步骤: 1. 创建一个实现了 `HandlerInterceptor` 接口的拦截器类,例如: ```java public class MyInterceptor implements HandlerInterceptor { // 在请求处理之前进行调用(Controller 方法调用之前) @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 执行拦截逻辑 return true; // 返回 true 表示继续执行后续的拦截器或处理器方法,返回 false 则中断后续操作 } // 在请求处理之后进行调用,但是在视图被渲染之前(Controller 方法调用之后) @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { // 执行拦截逻辑 } // 在整个请求结束之后被调用,也就是在 DispatcherServlet 渲染了对应的视图之后执行(主要用于资源清理操作) @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { // 执行拦截逻辑 } } ``` 2. 在 Spring MVC 配置文件中注册拦截器,例如在 `servlet-context.xml` 文件中添加以下代码: ```xml <mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/**"/> <!-- 拦截所有请求 --> <bean class="com.example.MyInterceptor"/> <!-- 拦截器类名 --> </mvc:interceptor> </mvc:interceptors> ``` 此配置将会拦截所有请求并应用 `MyInterceptor` 拦截器。 3. 配置完成后,当请求进入 Spring MVC 的 DispatcherServlet 时,拦截器将会按照配置的顺序执行相应的方法。 以上是使用 Spring MVC 配置拦截器的基本步骤,你可以根据实际需求自定义拦截器的逻辑和配置。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_koen

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值