Hibernate Validator深入剖析
在向大家詳細介紹Hibernate Validator之前,首先讓大家了解下Commons Validator 也有自己的缺陷,然后全面介紹Hibernate Validator。
更好的方法Hibernate Validator
進行驗證的一種典型方法是對簡單的驗證使用 Commons Validator,并在控制器中編寫其他一些驗證邏輯。Commons Validator 可以生成 JavaScript 來對視圖中的驗證進行處理。但是 Commons Validator 也有自己的缺陷:它只能處理簡單的驗證問題,并且將驗證的信息都保存到了 XML 文件中。Commons Validator 被設計用來與 Struts 一起使用,而且沒有提供一種簡單的方法在應用程序層間重用驗證的聲明。
在規劃有效性驗證策略時,選擇在錯誤發生時簡單地處理這些錯誤是遠遠不夠的。一種良好的設計同時還要通過生成一個友好的用戶界面來防止出現錯誤。采用預先進行的方法進行驗證可以極大地增強用戶對于應用程序的理解。不幸的是,Commons Validator 并沒有對此提供支持。假設希望 HTML 文件設置文本域的 maxlength 屬性來與驗證匹配,或者在文本域之后放上一個百分號(%)來表示要輸入百分比的值。通常,這些信息都被硬編寫到 HTML 文檔中了。如果決定修改 name 屬性來支持 75 個字符,而不是 60 個字符,那么需要改動多少地方呢?在很多應用程序中,通常都需要:
◆更新 DDL 來增大數據庫列的長度(通過 HibernateDoclet、 hbm.xml 或 Hibernate Annotations)。
◆更新 Commons Validator XML 文件將***值增加到 75。
◆更新所有與這個域有關的 HTML 表單,以修改 maxlength 屬性。
更好的方法是使用 Hibernate Validator。驗證的定義都被通過注釋 添加到了模型層中,同時還有對所包含的驗證處理的支持。如果選擇充分利用所有的 Hibernate,這個 Validator 就可以在 DAO 和 DBMS 層也提供驗證。在下面給出的樣例代碼中,將使用 reflection 和 JSP 2.0 標簽文件多執行一個步驟,從而充分利用注釋 為視圖層動態生成代碼。這可以清除在視圖中使用的硬編寫的業務邏輯。
dateOfBirth 被注釋為 NotNull 和過去的日期。 Hibernate 的 DDL 生成代碼對這個列添加了一個非空約束,以及一個要求日期必須是之前日期的檢查約束。e-mail 地址也是非空的,必須匹配 e-mail 地址的格式。這會生成一個非空約束,但是不會生成匹配這種格式的檢查約束。
- public class Contact implements Serializable {
- public static final int MAX_FIRST_NAME = 30;
- public static final int MAX_MIDDLE_NAME = 1;
- public static final int MAX_LAST_NAME = 30;
- private String fname;
- private String mi;
- private String lname;
- private Date dateOfBirth;
- private String emailAddress;
- private Address address;
- public Contact() {
- this.address = new Address();
- }
- @Valid
- @Embedded
- public Address getAddress() {
- return address;
- }
- public void setAddress(Address a) {
- if (a == null) {
- address = new Address();
- } else {
- aaddress = a;
- }
- }
- @NotNull
- @Length(min = 1, max = MAX_FIRST_NAME)
- @Column(name = "fname")
- public String getFirstname() {
- return fname;
- }
- public void setFirstname(String fname) {
- this.fname = fname;
- }
- @Length(min = 1, max = MAX_MIDDLE_NAME)
- @Column(name = "mi")
- public String getMi() {
- return mi;
- }
- public void setMi(String mi) {
- this.mi = mi;
- }
- @NotNull
- @Length(min = 1, max = MAX_LAST_NAME)
- @Column(name = "lname")
- public String getLastname() {
- return lname;
- }
如果需要,Hibernate DAO 實現也可以使用 Validation Annotations。所需做的是在 hibernate.cfg.xml 文件中指定基于 Hibernate 事件的驗證規則。(更多信息請參考 Hibernate Validator 的文檔;可以在 參考資料 一節中找到相關的鏈接)。如果真地希望抄近路,您可以只捕獲服務或控制器中的 InvalidStateException 異常,并循環遍歷 InvalidValue 數組。
【編輯推薦】