SpringMVC的拦截器和数据校验

时间:2022-02-02 08:29:56

SpringMVC拦截器

什么是拦截器:Spring MVC中的拦截器(Interceptor)类似于Servlet中的过滤器(Filter),它主要用于拦截用户请求并作相应的处理。例如通过拦截器可以进行权限验证、记录请求信息的日志、判断用户是否登录等。在SpringMVC中通过实现HandlerInterceptor接口实现自定义拦截器类。

Controller层

@Controller
@RequestMapping("/my")
public class MyController {
    @RequestMapping("/dofirst")
    public String  doFirst(){
        System.out.println("==========控制器中的方法=========");
        return "index";
    }

自定义拦截器类

public class MyIntercept implements HandlerInterceptor {
    /**
     * 在执行器 走之前执行的方法,改方法返回值为boolean,当为true代表放行,false为拦截器就不能执行到Controller
     * @param request
     * @param response
     * @param handler
     * @return
     * @throws Exception
     */

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("===========拦截器中的perHandle()方法============");
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("============在HandleAdapter之后执行,在DispatcherServlet解析试图之前执行===============");
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println("===================呈现之后调用==================");
    }
}

Spring-mvc.xml文件

<!--配置拦截器-->
<mvc:interceptors>
    <!--如果在此处又多套拦截器,则按照配置顺寻执行-->
    <mvc:interceptor>
        <mvc:mapping path="/my/**"/>
        <bean class="com.springmvc.interceptor.MyIntercept"/>
    </mvc:interceptor>
</mvc:interceptors>

拦截器的执行流程

SpringMVC的拦截器和数据校验

拦截器和过滤器的区别

过滤器

依赖于servlet容器。在实现上基于函数回调,可以对几乎所有请求进行过滤,但是缺点是一个过滤器实例只能在容器初始化时调用一次。使用过滤器的目的是用来做一些过滤操作,获取我们想要获取的数据,比如:在过滤器中修改字符编码;在过滤器中修改HttpServletRequest的一些参数,包括:过滤低俗文字、危险字符等。

拦截器

依赖于web框架,在SpringMVC中就是依赖于SpringMVC框架。在实现上基于Java的反射机制,属于面向切面编程(AOP)的一种运用。由于拦截器是基于web框架的调用,因此可以使用Spring的依赖注入(DI)进行一些业务操作,同时一个拦截器实例在一个controller生命周期之内可以多次调用。但是缺点是只能对controller请求进行拦截,对其他的一些比如直接访问静态资源的请求则没办法进行拦截处理。

SpringMVC数据校验

导入依赖

<!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-validator -->
<dependency>
  <groupId>org.hibernate</groupId>
  <artifactId>hibernate-validator</artifactId>
  <version>5.4.1.Final</version>
</dependency>

Jsp页面

<body>
    <form action="/my/validate" method="post">
        编号:<input type="text" name="user_id"/> <br/>
        姓名: <input type="text" name="user_name"/><br/>
        邮箱: <input type="text" name="user_email"/> <br/>
        手机号: <input type="text" name="user_phone"/> <br/>
        地址: <input type="text" name="user_address"/> <br/>
        身份证号: <input type="text" name="user_cardCode"/> <br/>
        <input type="submit" value="提交"/>
    </form>
</body>

编写实体类编写校验注解

@NotNull(message = "id不能为空")
private Integer user_id;
@NotNull(message = "姓名不能为空")
private String user_name;
@Email(message = "邮箱格式不正确")
private String user_email;
@Pattern(regexp = "1[3|5|7|8|]\\d{9}",message = "手机号格式不正确")
private String user_phone;
private String user_address;
@Pattern(regexp = "/^[1-9]\\d{5}(18|19|20)\\d{2}((0[1-9])|(1[0-2]))(([0-2][1-9])|10|20|30|31)\\d{3}[0-9Xx]$/",message = "身份证格式不正确")
private String user_cardCode;

Controller层

@RequestMapping("/validate")
    public String validate(@Valid UserInfo userInfo, BindingResult bindingResult){
        //如果有异常
    if (bindingResult.hasErrors()){
        //获取异常信息
        List<ObjectError> allErrors = bindingResult.getAllErrors();
        //将异常信息输出
        for (ObjectError error:allErrors){
            System.out.println(error.getDefaultMessage());
        }
    }
    return "index";
}

页面

SpringMVC的拦截器和数据校验

控制台

SpringMVC的拦截器和数据校验

数据校验注解使用

SpringMVC的拦截器和数据校验

SpringMVC的拦截器和数据校验