java中的Bean Validation
博客专区 > A__17 的博客 > 博客详情
java中的Bean Validation
A__17 发表于3个月前
java中的Bean Validation
  • 发表于 3个月前
  • 阅读 5
  • 收藏 0
  • 点赞 0
  • 评论 0

腾讯云 新注册用户 域名抢购1元起>>>   

概念:java中的Bean Validation是一个数据验证的规范。

说明:Hibernate Validator是Bean Validation的一个具体实现。

举例:在springMVC中使用Hibernate Validator

1)maven依赖:
	<dependency>
		<groupId>javax.validation</groupId>
		<artifactId>validation-api</artifactId>
		<version>1.1.0.Final</version>
	</dependency>
	<dependency>
		<groupId>org.hibernate</groupId>
		<artifactId>hibernate-validator</artifactId>
		<version>5.1.2.Final</version>
	</dependency>

2)JavaBean:

	import javax.validation.constraints.NotNull;
	import org.hibernate.validator.constraints.NotBlank;

	/**
	 * 在需要进行校验的属性上添加相应的注解:
	 * 
	 * 1)Bean Validation 提供的 constraint:       
	 * 		[@Null](https://my.oschina.net/u/561366)   	被注释的元素必须为 null       
	 *		[@NotNull](https://my.oschina.net/notnull)    被注释的元素必须不为 null       
	 *		@AssertTrue     被注释的元素必须为 true       
	 *		[@AssertFalse](https://my.oschina.net/u/2430840)    被注释的元素必须为 false       
	 *		@Min(value)     被注释的元素必须是一个数字,其值必须大于等于指定的最小值       
	 *		@Max(value)     被注释的元素必须是一个数字,其值必须小于等于指定的最大值       
	 *		@DecimalMin(value)  被注释的元素必须是一个数字,其值必须大于等于指定的最小值       
	 *		@DecimalMax(value)  被注释的元素必须是一个数字,其值必须小于等于指定的最大值       
	 *		@Size(max=, min=)   被注释的元素的大小必须在指定的范围内       
	 *		@Digits (integer, fraction)     被注释的元素必须是一个数字,其值必须在可接受的范围内       
	 *		@Past		 被注释的元素必须是一个过去的日期       
	 *		@Future		 被注释的元素必须是一个将来的日期       
	 *		@Pattern(regex=,flag=)  被注释的元素必须符合指定的正则表达式  
	 *		     
	 * 2)Hibernate Validator 特有的 constraint:
	 *		@NotBlank(message =)	验证字符串非null,且长度必须大于0 
	 *		@NotEmpty				被注释的字符串或集合的必须非空       
	 *		@Email  				被注释的元素必须符合email的格式       
	 *		@Length(min=,max=)		被注释的字符串的大小必须在指定的范围内             
	 *		@Range(min=,max=,message=)	被注释的元素必须在合适的范围内 
	 *		
	 */	
	public class User {
		 
		@NotBlank(message = "name is null!")
		private String name;

		@NotNull(message = "age is null!")
		private Integer age;

		private String email;

		private String address;

		// getter and setter ..
		
	}
	
3)控制器:

	import javax.validation.Valid;
	import org.springframework.validation.BindingResult;
	import org.springframework.validation.ObjectError;
	import org.springframework.web.bind.annotation.RequestMapping;
	import org.springframework.web.bind.annotation.RequestBody;
	import org.springframework.web.bind.annotation.RequestMethod;

	@RestController
	@RequestMapping("/sys")
	public class UserController {

		/**
		 * 1.给需要校验的参数添加 @Valid注解 
		 * 2.给方法添加一个类型为 BindingResult的参数,用来封装 校验的结果
		 */
		@RequestMapping(value = "/user/add", method = RequestMethod.POST)
		public String addUser(@Valid @RequestBody User req, BindingResult bindingResult) {
			
			if (bindingResult.hasErrors()) {
				List<ObjectError> allErrors = bindingResult.getAllErrors();
				List<String> msgs = new ArrayList<String>();
				for (ObjectError objectError : allErrors) {
					String msg = objectError.getDefaultMessage();
					msgs.add(msg);
				}
				String paramErrorMsg = StringUtils.join(msgs, " & ");
				return paramErrorMsg;
			} else {
				System.out.println("do add user.");
				return "success!";
			}
		}
	}

4)接口测试:

	地址:http://localhost:8081/jxn-web/api/sys/user/add
	
	请求类型:Content-Type: application/json

	参数:
		{"name":"","age":null}		==> 响应内容:age is null! & name is null!
		{"name":"","age":""}		==> 响应内容:age is null! & name is null!
		{"name":"jack","age":"17"}	==> 响应内容:success!

常见错误:

报错:javax.validation.UnexpectedTypeException: HV000030: No validator could be found for type: java.lang.Integer.

分析:是由于@NotBlank修饰了Integer、Long等引用类型的属性
eg:
	@NotBlank
	private Integer age;
	
修正:应该使用@NotNull来修饰引用类型的属性。
	@NotNull
	private Integer age;
共有 人打赏支持
粉丝 0
博文 35
码字总数 37964
×
A__17
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: