您好,登錄后才能下訂單哦!
這篇文章主要講解了“如何理解Hibernate Validator”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何理解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 數組。
感謝各位的閱讀,以上就是“如何理解Hibernate Validator”的內容了,經過本文的學習后,相信大家對如何理解Hibernate Validator這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。