文档章节

java中的Bean Validation

A__17
 A__17
发布于 2017/09/01 21:44
字数 732
阅读 8
收藏 0

概念: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;

© 著作权归作者所有

共有 人打赏支持
A__17
粉丝 2
博文 100
码字总数 116076
作品 0
朝阳
Java EE 6最终草案暗示了平台的未来发展方向

作者 Charles Humble 译者 张龙 发布于 2009年10月19日 下午1时4分 社区 Java 主题 Enterprise Application Blocks 标签 Java EE JSR-316(Java EE 6)专家组最近发布了规范的最终草案 。相对...

晨曦之光
2012/03/09
0
0
Bean Validation 技术规范特性概述

数据验证在 Java 分层结构的应用开发中占据着重要位置。Java EE 6 提出了 Bean Validation 规范,使用注解的方式对 Java Bean 进行约束验证,不局限于某一层次或者某一编程模型,灵活易用。本...

IBMdW
2011/03/28
0
0
Spring 3.0.0 is Now Available (2009-12-16)

Spring 3.0.0 is Now Available News and Announcements It's here just in time for the holidays! Arjen Poutsma has just announced that Spring 3.0.0 is now final and Juergen Hoeller......

晨曦之光
2012/03/09
0
0
CDI(Weld)整合整合JavaEE环境组件资源

除了基础部分和高级部分,CDI的第三个主题是整合。 CDI还设计了通过SPI提供集成点到Java EE平台的协同工作的平台之外的技术[在Java EE 6发布后,各种各样的Java EE平台扩展(构建在CDI扩展SPI之...

Zhao-Qian
2014/05/18
0
2
WildFly 13 "Baker's Dozen" 发布,改进 Java 10 兼容性

WildFly 13 Final 已正式发布,并提供了下载地址。下面不妨来看一下有哪些值得关注的更新。 EE8 功能和新的发布模型 这是使用新季度交付模式之后发布的第二个版本。该计划是在完全完成的增量...

局长
06/02
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

困扰当前数据中心管理的三大难题

导读 当企业发展到一定程度,或者之前的机房不能满足现在的数据中心使用时,企业会对数据中心进行迁移。那么在数据中心进行迁移的时候会遇到哪些风险呢?针对这些风险我们应该做出怎样的措施来...

问题终结者
5分钟前
0
0
设计模式:工厂方法模式(工厂模式)

工厂方法模式才是真正的工厂模式,前面讲到的静态工厂模式实际上不能说是一种真正意义上的设计模式,只是一种变成习惯。 工厂方法的类图: 这里面涉及到四个种类: 1、抽象产品: Product 2、...

京一
21分钟前
0
0
区块链和数据库,技术到底有何区别?

关于数据库和区块链,总会有很多的困惑。区块链其实是一种数据库,因为他是数字账本,并且在区块的数据结构上存储信息。数据库中存储信息的结构被称为表格。但是,区块链是数据库,数据库可不...

HiBlock
28分钟前
0
0
react native 开发碰到的问题

react-navigation v2 问题 问题: static navigationOptions = ({navigation, navigationOptions}) => ({ headerTitle: ( <Text style={{color:"#fff"}}>我的</Text> ), headerRight: ( <View......

罗培海
35分钟前
0
0
Mac Docker安装流程

久仰Docker大名已久,于是今天趁着有空,尝试了一下Docker 先是从docker的官网上下载下来mac版本的docker安装包,安装很简易,就直接拖图标就好了。 https://www.docker.com/products/docker...

writeademo
43分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部