您好,登錄后才能下訂單哦!
一、 spring-boot-starter-validation 依賴概述
上一篇 《Spring Boot Web 開(kāi)發(fā)注解篇》,就可以快速地進(jìn)行 Web 開(kāi)發(fā)。那么在表單提交的時(shí)候,我們需要進(jìn)行驗(yàn)證。前端驗(yàn)證可以擋住 99% 的小白用戶,這里要實(shí)現(xiàn)服務(wù)端驗(yàn)證。
Starters 機(jī)制告訴我們,只要加入 spring-boot-starter-validation 這個(gè) Starter ,就可以使用其實(shí)現(xiàn)驗(yàn)證。那什么是 spring-boot-starter-validation?
spring-boot-starter-validation 就是使用 Hibernate Validator 框架來(lái)提供 Java Bean 驗(yàn)證功能。
1.1 spring-boot-starter-validation 職責(zé)
spring-boot-starter-validation 是一個(gè)用于驗(yàn)證的 Starter,主要完成的是 Java Bean 的驗(yàn)證功能。
1.2 spring-boot-starter-validation 依賴關(guān)系
spring-boot-starter-validation 依賴的組成如下表:
可見(jiàn),tomcat 容器是 8.x 版本。這里有個(gè)小問(wèn)題了,為啥 spring-boot-starter-web 也有這些上面這些依賴呢?這樣如果開(kāi)發(fā) web 就不需要重復(fù)添加 spring-boot-starter-validation 依賴了。但如果沒(méi)用 web 依賴時(shí)候想要實(shí)現(xiàn) Bean 驗(yàn)證,則只要單單加入 spring-boot-starter-validation 依賴即可。
二、 運(yùn)行 chapter-4-spring-boot-validating-form-input 表單驗(yàn)證工程
1. git clone 下載工程 spring-boot-core-book-demo
項(xiàng)目地址見(jiàn) GitHub – https://github.com/JeffLi1993/spring-boot-core-book-demo:
git clone https://github.com/JeffLi1993/spring-boot-core-book-demo.git
2. Maven 編譯安裝這個(gè)工程:
cd spring-boot-core-book-demo mvn clean install
3. 運(yùn)行 chapter-4-spring-boot-validating-form-input 工程
右鍵項(xiàng)目 ValidatingFormInputApplication 類運(yùn)行即可:
2017-08-09 16:24:58.387 INFO 12193 — [ main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat started on port(s): 8080 (http) 2017-08-09 16:24:58.395 INFO 12193 — [ main] s.b.core.ValidatingFormInputApplication : Started ValidatingFormInputApplication in 9.846 seconds (JVM running for 11.23)
訪問(wèn) http://localhost:8080/users 用戶列表頁(yè)面:
點(diǎn)擊創(chuàng)建用戶按鈕,打開(kāi)用戶管理頁(yè)面:
輸入非法值提示:
三、 詳解 spring-boot-validating-form-input
1.pom.xml 如下:
validator 驗(yàn)證依賴主要在 web 依賴中,web 依賴包含了 hibernate-validator 依賴
還有以下依賴:
單元測(cè)試依賴
Spring Data JPA 依賴 :: 數(shù)據(jù)持久層框架
h3 數(shù)據(jù)源連接驅(qū)動(dòng)
模板引擎 Thymeleaf 依賴
2.實(shí)體類
具體業(yè)務(wù)層邏輯這邊不解釋,主要還是在控制層和 View 如何展示表單驗(yàn)證
實(shí)體類 User 如下:
@Entity public class User implements Serializable { /** * 編號(hào) */ @Id @GeneratedValue private Long id; /** * 名稱 */ @NotEmpty(message = “姓名不能為空”) @Size(min = 2, max = 8, message = “姓名長(zhǎng)度必須大于 2 且小于 20 字”) private String name; /** * 年齡 */ @NotNull(message = “年齡不能為空”) @Min(value = 0, message = “年齡大于 0”) @Max(value = 300, message = “年齡不大于 300”) private Integer age; /** * 出生時(shí)間 */ @NotEmpty(message = “出生時(shí)間不能為空”) private String birthday; public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; } public String getBirthday() { return birthday; } public void setBirthday(String birthday) { this.birthday = birthday; } @Override public String toString() { return “User{” + “id=” + id + “, name='” + name + ‘\” + “, age=” + age + “, birthday=” + birthday + ‘}'; } } @Entity @Id @GeneratedValue
以上注解是 JPA 框架提供的,實(shí)體類和表建立映射關(guān)系的。
Bean Validation 規(guī)范,運(yùn)行時(shí)的數(shù)據(jù)驗(yàn)證框架。它是 JSR 303 規(guī)范,Hibernate Validator 實(shí)現(xiàn)了這套規(guī)范,并擴(kuò)展了一些注解,如下:
@Null 被注釋的元素必須為 null
@NotNull 被注釋的元素必須不為 null
@Min(value) 被注釋的元素必須是一個(gè)數(shù)字,其值必須大于等于指定的最小值
@Max(value) 被注釋的元素必須是一個(gè)數(shù)字,其值必須小于等于指定的最大值
@Size(max, min) 被注釋的元素的大小必須在指定的范圍內(nèi)
@Email 被注釋的元素必須是電子郵箱地址
@Length 被注釋的字符串的大小必須在指定的范圍內(nèi)
@NotEmpty 被注釋的字符串的必須非空
@Range 被注釋的元素必須在合適的范圍內(nèi)
3.控制層 UserController
UserController 控制層代碼如下:
/** * 創(chuàng)建用戶 * 處理 “/users” 的 POST 請(qǐng)求,用來(lái)獲取用戶列表 * 通過(guò) @ModelAttribute 綁定參數(shù),也通過(guò) @RequestParam 從頁(yè)面中傳遞參數(shù) */ @RequestMapping(value = “/create”, method = RequestMethod.POST) public String postUser(ModelMap map, @ModelAttribute @Valid User user, BindingResult bindingResult) { if (bindingResult.hasErrors()) { map.addAttribute(“action”, “create”); return “userForm”; } userService.insertByUser(user); return “redirect:/users/”; } /** * 處理 “/users/{id}” 的 PUT 請(qǐng)求,用來(lái)更新 User 信息 * */ @RequestMapping(value = “/update”, method = RequestMethod.POST) public String putUser(ModelMap map, @ModelAttribute @Valid User user, BindingResult bindingResult) { if (bindingResult.hasErrors()) { map.addAttribute(“action”, “update”); return “userForm”; } userService.update(user); return “redirect:/users/”; }
在新增和更新用戶時(shí),我們會(huì)對(duì)表單進(jìn)行驗(yàn)證,那么首先用 @Valid 注解到實(shí)體類,使實(shí)體類 User 中驗(yàn)證注解生效,然后我們介紹下 BindingResult ,是數(shù)據(jù)綁定的結(jié)果對(duì)象,從源碼中可以看出,其繼承了 Errors 接口,所以所有的錯(cuò)誤信息都會(huì)被綁定到這個(gè)對(duì)象。通過(guò) hasErrors() 方法判斷是否有錯(cuò)誤信息,如果有返回原頁(yè)面,并展示錯(cuò)誤信息。
總結(jié)
以上所述是小編給大家介紹的Spring Boot 表單驗(yàn)證篇,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)億速云網(wǎng)站的支持!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。