Spring MVC的数据校验

数据检验
顾名思义就是对用户提交的数据进行检验(比如非空验证,一些正则表达式的验证等)。在前端(HTML或JSP中)有数据校验的机制,在后端代码上也有此机制。等于给数据提供双保险校验、SpringMVC就为后端提供数据校验的机制。

SpringMVC提供两种数据校验的方式:
(1)基于Validator接口
(2)使用Annocation JSR-303标准进行验证。

基于 Validator 接⼝的⽅式需要⾃定义 Validator 验证器,每⼀条数据的验证规则需要开发者⼿动完成,使⽤ Annotation JSR - 303 标准则不需要⾃定义验证器,通过注解的⽅式可以直接在实体类中添加每个属性的验证规则,这种⽅式更加⽅便,实际开发中推荐使⽤。

基于Validator接口

实体类 Account


package com.southwind.entity;
import lombok.Data;
@Data
public class Account {
 private String name;
 private String password; 
}

⾃定义验证器 AccountValidator,实现 Validator 接⼝

public class AccountValidator implements Validator{

    @Override
    public boolean supports(Class<?> aClass) {
        return Account.class.equals(aClass);
    }

    @Override
    public void validate(Object o, Errors errors) {
        ValidationUtils.rejectIfEmpty(errors,"name",null,"姓名不能为空");
        ValidationUtils.rejectIfEmpty(errors,"password",null,"密码不能为空");
    }
}

springmvc.xml 配置验证器

<bean id="accountValidator" class="com.southwind.validator.AccountValidator">
</bean> <mvc:annotation-driven validator="accountValidator"></mvc:annotation-driven>

JSP


 <form:form modelAttribute="account" action="/validator/login"
	method="post">
 姓名:<form:input path="name"/><from:errors 		path="name"></from:errors> <br/>
 密码:<form:input path="password"/><from:errors path="password">
</from:errors><br/>
 <input type="submit" value="登录"/>
 </form:form>
 

使用Annocation JSR-303标准进行验证

使⽤ Annotation JSR - 303 标准进⾏验证,需要导⼊⽀持这种标准的依赖 jar ⽂件,这⾥我们使⽤Hibernate Validator

pom.xml导入jar包


<!-- JSR-303 -->
<dependency>
 <groupId>org.hibernate</groupId>
 <artifactId>hibernate-validator</artifactId>
 <version>5.3.6.Final</version>
</dependency> <dependency>
 <groupId>javax.validation</groupId>
 <artifactId>validation-api</artifactId>
 <version>2.0.1.Final</version>
</dependency> <dependency>
 <groupId>org.jboss.logging</groupId>
 <artifactId>jboss-logging</artifactId>
 <version>3.3.2.Final</version>
</dependency>

实体类

通过注解的⽅式直接在实体类中添加相关的验证规则。


@Data
public class Person {
 @NotEmpty(message = "⽤户名不能为空")
 private String username;
 @Size(min = 6,max = 12,message = "密码6-12位")
 private String password;
 @Email(regexp = "^[a-zA-Z0-9_.-]+@[a-zA-Z0-9-]+(\\\\.[a-zA-Z0-9-]+)*\\\\.
[a-zA-Z0-9]{2,6}$",message = "请输⼊正确的邮箱格式")
 private String email;
 @Pattern(regexp = "^((13[0-9])|(14[5|7])|(15([0-3]|[5-9]))|(18[0,5-
9]))\\\\\\\\d{8}$",message = "请输⼊正确的电话")
 private String phone; }

ValidatorHandler


@GetMapping("/register")
public String register(Model model){
 model.addAttribute("person",new Person());
 return "register"; }
@PostMapping("/register")
public String register(@Valid Person person, BindingResult bindingResult){
 if(bindingResult.hasErrors()){
 return "register";
 }
 return "index"; }

斜体样式


<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ page isELIgnored="false" %>
<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>
<html> <head>
 <title>Title</title>
</head> <body>
 <form:form modelAttribute="person" action="/validator/register2"
method="post">
 ⽤户名:<form:input path="username"></form:input><form:errors
path="username"/><br/>
 密码:<form:password path="password"></form:password><form:errors
path="password"/><br/>
 邮箱:<form:input path="email"></form:input><form:errors path="email"/>
<br/>
 电话:<form:input path="phone"></form:input><form:errors path="phone"/>
<br/>
 <input type="submit" value="提交"/>
 </form:form>
</body>
</html>

校验规则详解:
@Null 被注解的元素必须为null
@NotNull 被注解的元素不能为null
@Min(value) 被注解的元素必须是⼀个数字,其值必须⼤于等于指定的最⼩值
@Max(value) 被注解的元素必须是⼀个数字,其值必须⼩于于等于指定的最⼤值
@Email 被注解的元素必须是电⼦邮箱地址
@Pattern 被注解的元素必须符合对应的正则表达式
@Length 被注解的元素的⼤⼩必须在指定的范围内
@NotEmpty 被注解的字符串的值必须⾮空
Null 和 Empty 是不同的结果,String str = null,str 是 null,String str = “”,str 不是 null,其值为

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值