詳解SpringMVC驗(yàn)證框架Validation特殊用法
基本用法不說了,網(wǎng)上例子很多,這里主要介紹下比較特殊情況下使用的方法。
1. 分組
有的時候,我們對一個實(shí)體類需要有多中驗(yàn)證方式,在不同的情況下使用不同驗(yàn)證方式,比如說對于一個實(shí)體類來的id來說,保存的時候是不需要的,對于更新時是必須的,可以如下配置:
public class UserModel { @NotNull(message = "{id.empty}", groups = { First.class }) private int id; @NotNull(message = "{username.empty}", groups = { First.class, Second.class }) private String username; @NotNull(message = "{content.empty}", groups = { First.class, Second.class }) private String content; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getContent() { return content; } public void setContent(String content) { this.content = content; } } public interface First { } public interface Second { }
通過 groups 對驗(yàn)證進(jìn)行分組
在controler中的代碼如下:
@RequestMapping(value = "/save.action", method = RequestMethod.POST) public String save(@Validated( { Second.class }) UserModel userModel, BindingResult result) { if (result.hasErrors()) { return "validate/error"; } return "redirect:/success"; } @RequestMapping(value = "/update.action", method = RequestMethod.POST) public String update(@Validated( { First.class, Second.class }) UserModel user, BindingResult result) { if (result.hasErrors()) { return "validate/error"; } return "redirect:/success"; }
2. 組序列
默認(rèn)情況下,不同組別的約束驗(yàn)證是無序的,然而在某些情況下,約束驗(yàn)證的順序卻很重要,如下面兩個例子:(1)第二個組中的約束驗(yàn)證依賴于一個穩(wěn)定狀態(tài)來運(yùn)行,而這個穩(wěn)定狀態(tài)是由第一個組來進(jìn)行驗(yàn)證的。(2)某個組的驗(yàn)證比較耗時,CPU 和內(nèi)存的使用率相對比較大,最優(yōu)的選擇是將其放在最后進(jìn)行驗(yàn)證。因此,在進(jìn)行組驗(yàn)證的時候尚需提供一種有序的驗(yàn)證方式,這就提出了組序列的概念。
一個組可以定義為其他組的序列,使用它進(jìn)行驗(yàn)證的時候必須符合該序列規(guī)定的順序。在使用組序列驗(yàn)證的時候,如果序列前邊的組驗(yàn)證失敗,則后面的組將不再給予驗(yàn)證。
下例中聲明了組 GroupA.class,GroupB.class 和 Group.class,其中 default,GroupA,GroupB 均為 Group 的序列。
public interface GroupA { } public interface GroupB { } @GroupSequence( { Default.class, GroupA.class, GroupB.class }) public interface Group { } public class User { @NotEmpty(message = "firstname may be empty") private String firstname; @NotEmpty(message = "middlename may be empty", groups = Default.class) private String middlename; @NotEmpty(message = "lastname may be empty", groups = GroupA.class) private String lastname; @NotEmpty(message = "country may be empty", groups = GroupB.class) private String country; } [java] view plain copy 在CODE上查看代碼片派生到我的代碼片 @RequestMapping(value = "/update.action", method = RequestMethod.POST) public String register(@Validated(Group.class) User user, BindingResult result) { if (result.hasErrors()) { return "validate/error"; } return "redirect:/success"; }
3. 驗(yàn)證多個對象
當(dāng)我們在一個功能處理方法上需要驗(yàn)證多個模型對象時,需要通過如下形式來獲取驗(yàn)證結(jié)果:
@RequestMapping("/validate/multi") public String multi(@Valid @ModelAttribute("a") A a, BindingResult aErrors, @Valid @ModelAttribute("b") B b, BindingResult bErrors) { if (aErrors.hasErrors()) { //如果a模型對象驗(yàn)證失敗 return "validate/error"; } if (bErrors.hasErrors()) { //如果a模型對象驗(yàn)證失敗 return "validate/error"; } return "redirect:/success"; }
每一個模型對象后邊都需要跟一個Errors或BindingResult對象來保存驗(yàn)證結(jié)果,其方法體內(nèi)部可以使用這兩個驗(yàn)證結(jié)果對象來選擇出錯時跳轉(zhuǎn)的頁面或處理的邏輯。
4. Junit測試
當(dāng)自定義拓展Validation時,可以使用如下方法進(jìn)行測試:
@Test public void testValidate() { AnnotationDescriptor<EqualsAny> descriptor = new AnnotationDescriptor<EqualsAny>(EqualsAny.class); EqualsAny equalsAny = AnnotationFactory.create(descriptor); EqualsAnyValidator equalsAnyValidator = new EqualsAnyValidator(); equalsAnyValidator.initialize(equalsAny); Assert.assertTrue(equalsAnyValidator.isValid("123", null)); }
另外再講一點(diǎn)spring對自定義JSR-303限制類型支持的新特性,那就是Spring支持往ConstraintValidator里面注入bean對象。例如在EqualsAnyValidator中利用@Resource注解注入其他Bean對象。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
IDEA中Spring項(xiàng)目的工程構(gòu)建
這篇文章主要介紹了IDEA中Spring項(xiàng)目的工程構(gòu)建,Spring框架是輕量級的JavaEE框架,可以解決企業(yè)應(yīng)用開發(fā)的復(fù)雜性,有兩個核心部分:IOC和Aop,今天來學(xué)習(xí)如何構(gòu)建spring項(xiàng)目,需要的朋友可以參考下2023-05-05mapstruct的用法之qualifiedByName示例詳解
qualifiedByName的意思就是使用這個Mapper接口中的指定的默認(rèn)方法去處理這個屬性的轉(zhuǎn)換,而不是簡單的get?set,今天通過本文給大家介紹下mapstruct的用法之qualifiedByName示例詳解,感興趣的朋友一起看看吧2022-04-04SSO單點(diǎn)登錄系統(tǒng)實(shí)現(xiàn)原理及流程圖解
這篇文章主要介紹了SSO單點(diǎn)登錄系統(tǒng)實(shí)現(xiàn)原理及流程圖解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-12-12Java如何將字符串String轉(zhuǎn)換為整型Int
這篇文章主要介紹了Java如何將字符串String轉(zhuǎn)換為整型Int,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下2022-08-08dm.jdbc.driver.DMException網(wǎng)絡(luò)通信異常的解決過程
最近一個項(xiàng)目里面出現(xiàn)了一個比較詭異的問題,給大家分享下,這篇文章主要給大家介紹了關(guān)于dm.jdbc.driver.DMException網(wǎng)絡(luò)通信異常的解決過程,需要的朋友可以參考下2023-02-02SpringBoot集成SpringSecurity和JWT做登陸鑒權(quán)的實(shí)現(xiàn)
這篇文章主要介紹了SpringBoot集成SpringSecurity和JWT做登陸鑒權(quán)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04JAVA中的延遲隊(duì)列DelayQueue應(yīng)用解析
這篇文章主要介紹了JAVA中的延遲隊(duì)列DelayQueue應(yīng)用解析,DelayQueue是一個根據(jù)元素的到期時間來排序的隊(duì)列,而并非是一般的隊(duì)列那樣先進(jìn)先出,最快過期的元素排在隊(duì)首,越晚到期的元素排得越后,需要的朋友可以參考下2023-12-12