Hibernate Validator 6.0.0.Alpha2 发布了。Hibernate Validator 6 将成为 Bean Validation 2.0 的参考实现。此 Alpha2 版本与 Bean Validation 规范的 2.0.0.Alpha2 版本协调。
请注意,Hibernate Validator 6 需要 JDK 8 或更高版本。
自 Alpha1 以来的新功能
改进对容器元素验证的支持
Container element validation support is the big new feature of Bean Validation 2.0 and it got some more love during this cycle.
编程 API 和 XML 支持
To obtain the equivalent of:
public class FishTank {
private Optional<@Valid FishTankModel> model;
private Map<@Size(min = 3, max = 10) String, @Min(1) Integer> fishCountByType;
}
it is now possible to declare container element type constraints and cascaded validation either via an XML mapping configuration (which is part of the Bean Validation 2.0 specification):
[...]
class="com.acme.FishTank" ignore-annotations="false">
name="model">
/>
name="fishCountByType">
typeArgumentIndex="0">
annotation="javax.validation.constraints.Size">
name="min">
3
name="max">
10
typeArgumentIndex="1">
annotation="javax.validation.constraints.Min">
name="value">
1
[...]
or via the (implementation specific) programmatic API:
ConstraintMapping newMapping = config.createConstraintMapping();
newMapping
.type( FishTank.class )
.property( "model", FIELD )
.containerElementType()
.valid()
.property( "fishCountByType", FIELD )
.containerElementType( 0 )
.constraint( new SizeDef().min( 3 ).max( 10 ) )
.containerElementType( 1 )
.constraint( new MinDef().value( 1 ) );
其他改进
We also made a couple of more minor improvements:
the TYPE_ARGUMENT node type has been renamed to CONTAINER_ELEMENT (type argument don’t make sense for annotated array elements)
we allow per context custom value extractors
we allow value extractors to be contributed using the service loader mechanism
we allow to specify value extractors using XML configuration
we explore the parent classes and interfaces to search the ValueExtractor definition
支持添加到 Bean Validation 2.0 的新约束
In the Alpha2 release of Bean Validation 2.0, we introduced the following new constraints:
@NotBlank: check that a char sequence is not blank (i.e. not null, and length of trimmed char sequence > 0)
@NotEmpty: check that an element (char sequence, collection, array) is not null and not empty
@Email: check that a char sequence is a valid email
@Positive: check that a number is positive
@Negative: check that a number is negative
We added support for these new constraints to Hibernate Validator.
性能改进
We started to run a few benchmarks on Hibernate Validator 6 and we fixed a few performance regressions.
6.0.0.Alpha2 is now significantly faster than 5.4, mostly thanks to the new ValueExtractor design.
获取 6.0.0.Alpha2
To get the release with Maven, Gradle etc. use the GAV coordinates org.hibernate.validator:{hibernate-validator|hibernate-validator-cdi|hibernate-validator-annotation-processor}:6.0.0.Alpha2. Note that the group id has changed from org.hibernate (Hibernate Validator 5 and earlier) to org.hibernate.validator (from Hibernate Validator 6 onwards).
Alternatively, a distribution bundle containing all the bits is provided on SourceForge (TAR.GZ, ZIP).
反馈, issues, 建议?
To get in touch, use the usual channels:
hibernate-validator tag on * (usage questions)
User forum (usage questions, general feedback)
Issue tracker (bug reports, feature requests)
Mailing list (development-related discussions)
Bean Validation development mailing list (discussions about the Bean Validation specification)
下一步是什么?
Bean Validation 2.0 和 Hibernate Validator 6 仍在积极开发中,会定期发布新的 alpha 版本。
本文来自开源中国社区 [http://www.oschina.net]