【51CTO精選譯文】對於Sun最新發布的Java EE 6平台,過去51CTO已經陸續介紹了平台的主要目標,以及三大新技術中的JAX-RS以及上下文和依賴注入。本文介紹第三個技術:Bean驗證。
驗證數據是應用程序生命周期中一個常見的任務,例如,在應用程序的表示層,你可能想驗證用戶在文本框中輸入的字符數最多不超過20個,或者想驗證用戶在數字字段輸入的字符只能是數字。
開發人員在應用程序的各層中通常使用相同的驗證邏輯,或者將驗證邏輯放在數據模型中。
Bean驗證(JSR 303)使驗證變得更簡單了,減少了重復,錯誤和凌亂,Bean驗證提供了一個標准的驗證框架,在框架中相同的驗證集可以在應用程序的所有層之間共享。
Bean驗證提供了一個框架驗證遵循JavaBean規范編寫的Java類,你可以使用注解指定一個JavaBean上的約束,你可以注解一個JavaBean類、字段或屬性,你也可以通過XML描述符擴展或覆蓋這些約束,驗證類驗證每個約束時,你要指定那個驗證類用於給定的約束類型。
例如,下面是通過Bean驗證注解聲明一些約束的類的一部分代碼:
- public class Address {
- @NotNull @Size(max=30)
- private String addressline1;
- @Size(max=30)
- private String addressline2;
- ...
- public String getAddressline1() {
- return addressline1;
- }
- public void setAddressline1(String addressline1) {
- this.addressline1 = addressline1;
- }
- ...
- }
@NotNull注解指定了注解元素addressline1絕不能為空,@Size注解指定注解元素addressline1和addressline2決不能大於指定的長度(30個字符)。
驗證Address對象時,addressline1的值傳遞給為@NotNull約束定義的驗證類,同時還要傳遞給為@Size約束定義的驗證類,addressline2的值也要傳遞給為@Size約束定義的驗證類。
51CTO編輯推薦:Java EE 6平台指南
@NotNull 和@Size約束內置於Bean驗證框架中,因此你不需要為它們定義驗證類,但你可以在內置約束上添加自己的約束,那時就需要定義自己的驗證類了。例如,你可以定義如下的@ZipCode約束:
- @Size(min=5, max=5)
- @ConstraintValidator(ZipcodeValidator.class)
- @Documented
- @Target({ANNOTATION_TYPE, METHOD, FIELD})
- @Retention(RUNTIME)
- public @interface ZipCode {
- String message() default "Wrong zipcode";
- String[] groups() default {};
- }
然後你可以在類、字段或屬性上象其它約束定義那樣定義@ZipCode約束,如:
- public class Address {
- ...
- @ZipCode
- private String addressline 3;
- public String getZipCode() {
- return zipCode;
- }
- public void setZipCode(String zipCode) {
- this.zipCode = zipCode;
- }
- ...
- }
你也可以使用Bean驗證驗證一個完整的對象圖(object graph),一個對象圖是由其它對象組成的一個對象,如果你在對象圖的根對象上指定@Valid注解,它會指引相關的驗證器遞歸驗證對象圖中的關聯對象,如:
- public class Order {
- @OrderNumber private String orderNumber;
- @Valid @NotNull private Address delivery;
- }
Order對象驗證後,Address對象和對象圖中關聯的對象也被驗證。
為了滿足在應用程序各層之間共享相同的驗證集,Java EE 6平台整合了Bean驗證。例如,表示層技術,如JSF,以及企業級技術,如JPA,都可以通過Bean驗證框架訪問約束定義和驗證器,你不再需要在多個地方指定約束。
原文:Introducing the Java EE 6 Platform