詳解如何在Spring Boot項(xiàng)目使用參數(shù)校驗(yàn)
開發(fā)web項(xiàng)目有時(shí)候我們需要對(duì)controller層傳過來的參數(shù)進(jìn)行一些基本的校驗(yàn),比如非空,非null,整數(shù)值的范圍,字符串的個(gè)數(shù),日期,郵箱等等。最常見的就是我們直接寫代碼校驗(yàn),這樣以后比較繁瑣,而且不夠靈活。
Bean Validation 1.0(JSR-303)是一個(gè)校驗(yàn)規(guī)范,在spring Boot項(xiàng)目由于自帶了hibernate validator 5(http://hibernate.org/validator/)實(shí)現(xiàn),所以我們可以非常方便的使用這個(gè)特性 。
核心的pom依賴:
<dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-validator</artifactId> <version>5.3.1.Final</version> </dependency>
首先,需要我們聲明一個(gè)Bean,注入校驗(yàn)器到Spring Boot的運(yùn)行環(huán)境
@Configuration @EnableAutoConfiguration public class FactoryConfig { final static Logger logger= LoggerFactory.getLogger(FactoryConfig.class); @Bean public MethodValidationPostProcessor methodValidationPostProcessor(){ return new MethodValidationPostProcessor(); } }
校驗(yàn)常用的注解如下:
@AssertFalse 校驗(yàn)false @AssertTrue 校驗(yàn)true @DecimalMax(value=,inclusive=) 小于等于value, inclusive=true,是小于等于 @DecimalMin(value=,inclusive=) 與上類似 @Max(value=) 小于等于value @Min(value=) 大于等于value @NotNull 檢查Null @Past 檢查日期 @Pattern(regex=,flag=) 正則 @Size(min=, max=) 字符串,集合,map限制大小 @Valid 對(duì)po實(shí)體類進(jìn)行校驗(yàn)
下面看一個(gè)使用例子:
package hello; import javax.validation.constraints.Min; import javax.validation.constraints.NotNull; import javax.validation.constraints.Size; public class PersonForm { //名字不能為空,而且長度必須在2和30之間 @NotNull(message = "名稱不能為空") @Size(min=2, max=30, message = "名字長度必須在2和30之間") private String name; //年齡不能為空,而且必須大于等于18歲 @NotNull @Min(18) private Integer age; public String getName() { return this.name; } public void setName(String name) { this.name = name; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; } public String toString() { return "Person(Name: " + this.name + ", Age: " + this.age + ")"; } }
接著看下如何在Controller層使用
//非實(shí)體類參數(shù)可以直接使用注解 @GetMapping("/check") @ResponseBody public String check(@Min(0,message = "kpId必須大于等于0") @RequestParam int kpId,@RequestParam int level) { return "ok"; } //實(shí)體類注解校驗(yàn)使用@Valid @PostMapping("/") public String checkPersonInfo(@Valid PersonForm personForm, BindingResult bindingResult) { if (bindingResult.hasErrors()) { return "form"; } return "redirect:/results"; }
注意上面的Spring提供的BindingResult是錯(cuò)誤結(jié)果的一個(gè)封裝,我們可以在web頁面中通過這個(gè)對(duì)象拿到詳細(xì)的錯(cuò)誤信息,
<td th:if="${#fields.hasErrors('age')}" th:errors="*{age}">Age Error</td>
總結(jié):
通過使用注解來快速檢驗(yàn)傳入的web參數(shù)還是非常簡(jiǎn)潔強(qiáng)大的,這里僅僅列舉了一小部分的校驗(yàn)的知識(shí),希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Centos7安裝JDK1.8詳細(xì)過程實(shí)戰(zhàn)記錄
這篇文章主要給大家介紹了關(guān)于Centos7安裝JDK1.8的相關(guān)資料,文中通過圖文以及實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-09-09spring學(xué)習(xí)之@SessionAttributes實(shí)例解析
這篇文章主要介紹了spring學(xué)習(xí)之@SessionAttributes實(shí)例解析,分享了相關(guān)代碼示例,小編覺得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-02-02SpringBoot項(xiàng)目中使用Swagger2及注解解釋的詳細(xì)教程
Swagger2是一個(gè)開源項(xiàng)目,用于為RESTful Web服務(wù)生成REST API文檔,下面這篇文章主要給大家介紹了關(guān)于SpringBoot項(xiàng)目中使用Swagger2及注解解釋的詳細(xì)教程,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-04-04SpringBoot淺析安全管理之基于數(shù)據(jù)庫認(rèn)證
在真實(shí)的項(xiàng)目中,用戶的基本信息以及角色等都存儲(chǔ)在數(shù)據(jù)庫中,因此需要從數(shù)據(jù)庫中獲取數(shù)據(jù)進(jìn)行認(rèn)證和授權(quán)2022-08-08Java實(shí)戰(zhàn)之王者榮耀的英雄是怎么產(chǎn)生的?
這篇文章主要介紹了Java實(shí)戰(zhàn)之王者榮耀的英雄是怎么產(chǎn)生的?文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)java的小伙伴們有很好地幫助,需要的朋友可以參考下2021-05-05一文掌握J(rèn)ava開發(fā)工具M(jìn)aven(簡(jiǎn)單上手)
掌握maven的相關(guān)知識(shí)是Java開發(fā)必備的技能,今天通過本文從入門安裝開始,逐步深入講解maven的相關(guān)知識(shí),包括maven的安裝到簡(jiǎn)單上手maven項(xiàng)目開發(fā),感興趣的朋友跟隨小編一起看看吧2021-06-06