摘要:前言估計很多朋友都認(rèn)為參數(shù)校驗(yàn)是客戶端的職責(zé),不關(guān)服務(wù)端的事。輕則導(dǎo)致服務(wù)器宕機(jī),重則泄露數(shù)據(jù)。所以,這時就需要設(shè)置第二道關(guān)卡,服務(wù)端驗(yàn)證了。老項目的服務(wù)端校驗(yàn)不能為空不能為空看以上代碼,就一個的校驗(yàn)就如此麻煩。
前言
估計很多朋友都認(rèn)為參數(shù)校驗(yàn)是客戶端的職責(zé),不關(guān)服務(wù)端的事。其實(shí)這是錯誤的,學(xué)過 Web 安全的都知道,客戶端的驗(yàn)證只是第一道關(guān)卡。它的參數(shù)驗(yàn)證并不是安全的,一旦被有心人抓到可乘之機(jī),他就可以有各種方法來摸擬系統(tǒng)的 Http 請求,訪問數(shù)據(jù)庫的關(guān)鍵數(shù)據(jù)。輕則導(dǎo)致服務(wù)器宕機(jī),重則泄露數(shù)據(jù)。所以,這時就需要設(shè)置第二道關(guān)卡,服務(wù)端驗(yàn)證了。
老項目的服務(wù)端校驗(yàn)@RestController @RequestMapping("/student") public class ValidateOneController { @GetMapping("/id") public Student findStudentById(Integer id){ if(id == null){ logger.error("id 不能為空!"); throw new NullPointerException("id 不能為空"); } return studentService.findStudentById(id); } }
看以上代碼,就一個的校驗(yàn)就如此麻煩。那我們是否有好的統(tǒng)一校驗(yàn)方法呢?鑒于 SpringBoot 無所不能。答案當(dāng)然是有的。
其中,Bean Validator 和 Hibernate Validator 就是兩套用于驗(yàn)證的框架,二者都遵循 JSR-303 ,可以混著用,鑒于二者的某些 Validator 注解有差別,例如 @Length 在 Bean Validator 中是沒有的,所以這里我選擇混合用。
JSR-303JSR-303 是JAVA EE 6 中的一項子規(guī)范,叫做 Bean Validation,Hibernate Validator 是 Bean Validation 的參考實(shí)現(xiàn), Hibernate Validator 提供了 JSR 303 規(guī)范中所有內(nèi)置 Constraint(約束) 的實(shí)現(xiàn),除此之外還有一些附加的 Constraint 。這些 Constraint (約束) 全都通過注解的方式實(shí)現(xiàn),請看下面兩個表。
Bean Validation 中內(nèi)置的約束:
注解 | 作用 |
---|---|
@Null | 被注解參數(shù)必須為空 |
@NotNull | 被注解參數(shù)不能為空 |
@AssertTrue | 被注解參數(shù)必須為 True |
@AssertFalse | 被注解參數(shù)必須為 False |
@Min(value) | 被注解參數(shù)必須是數(shù)字,且其值必須大于等于 value |
@Max(value) | 被注解參數(shù)必須是數(shù)字,且其值必須小于等于 value |
@DecimaMin(value) | 被注解參數(shù)必須是數(shù)字,且其值必須大于等于 value |
@DecimaMax(value) | 被注解參數(shù)必須是數(shù)字,且其值必須小于等于 value |
@Size(max, min) | 被注解參數(shù)大小必須在指定范圍內(nèi) |
@Past | 被注解參數(shù)必須是一個過去的日期 |
@Future | 被注解參數(shù)必須是一個將來的日期 |
@Pattern(value) | 被注解參數(shù)必須符合指定的正則表達(dá)式 |
@Digits(integer, fraction) | 被注解參數(shù)必須是數(shù)字,且其值必須在可接受范圍內(nèi) |
@NotBlank | 被注解參數(shù)的值不為空(不為 null、去除首位空格后長度為 0),不同于 @NotEmpty,@NotBlank 只應(yīng)用于字符串且在比較時會去除字符串的空格 |
Hibernate Validator 附加的約束:
注解 | 作用 |
---|---|
@NotEmpty | 被注解參數(shù)的值不為 null 且不為空(字符串長度不為0、集合大小不為0) |
被注解參數(shù)必須是電子郵箱地址 | |
@Length | 被注解的字符串長度必須在指定范圍內(nèi) |
@Range | 被注解的參數(shù)必須在指定范圍內(nèi) |
SpringBoot 2.1.3
IDEA
JDK8
Pom 文件依賴實(shí)體類org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-test test org.projectlombok lombok true
用于測試,加入了參數(shù)校驗(yàn)規(guī)則。
@Data @AllArgsConstructor @NoArgsConstructor public class Student { private Integer id; @NotBlank(message = "學(xué)生名字不能為空") @Length(min = 2, max = 10, message = "name 長度必須在 {min} - {max} 之間") private String name; @NotNull(message = "年齡不允許為空") @Min(value = 0, message = "年齡不能低于 {value} 歲") private Integer age; }Controller 層
寫了兩個方法,一個用于校驗(yàn)普通參數(shù),一個用于校驗(yàn)對象
@Validated //開啟數(shù)據(jù)校驗(yàn),添加在類上用于校驗(yàn)方法,添加在方法參數(shù)中用于校驗(yàn)參數(shù)對象。(添加在方法上無效) @RestController @RequestMapping("/student") public class ValidateOneController { /** * 普通參數(shù)校驗(yàn) * @param name * @return */ @GetMapping("/name") public String findStudentByName(@NotBlank(message = "學(xué)生名字不能為空") @Length(min = 2, max = 10, message = "name 長度必須在 {min} - {max} 之間")String name){ return "success"; } /** * 對象校驗(yàn) * @param student * @return */ @PostMapping("/add") public String addStudent(@Validated @RequestBody Student student){ return "success"; } }Postman 測試
校驗(yàn)普通參數(shù)測試結(jié)果:
下圖可以看見,我沒有在 http://localhost:8080/student/name 地址后添加 name 參數(shù),傳到后臺馬上就校驗(yàn)出異常了。而這個異常信息就是我定義的校驗(yàn)異常信息。
校驗(yàn)對象測試結(jié)果:
結(jié)果有點(diǎn)長:
下圖可以看見,我訪問 http://localhost:8080/student/add 傳入了參數(shù)對象,但對象是不能通過校驗(yàn)規(guī)則的,比如 age 參數(shù)為負(fù)數(shù),name 參數(shù)長度太大,傳到后臺馬上就校驗(yàn)出異常了。而這個異常信息就是我定義的校驗(yàn)異常信息。
完整代碼https://github.com/turoDog/De...
如果覺得對你有幫助,請給個 Star 再走唄,非常感謝。
后語如果本文對你哪怕有一丁點(diǎn)幫助,請幫忙點(diǎn)好看。你的好看是我堅持寫作的動力。
另外,關(guān)注之后在發(fā)送 1024 可領(lǐng)取免費(fèi)學(xué)習(xí)資料。
資料詳情請看這篇舊文:Python、C++、Java、Linux、Go、前端、算法資料分享
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/73522.html
摘要:注冊流程是從小程序簡稱,以下替代獲取用戶的,給到服務(wù)器,服務(wù)器會用還有自己的等信息一起去微信服務(wù)器請求用戶數(shù)據(jù),注意每一個所對應(yīng)的用戶都是不一樣的。 本博客 貓叔的博客,轉(zhuǎn)載請申明出處閱讀本文約 5分鐘適讀人群:Java后端、Java初級、小程序前端 前后端項目的地址 ShareBookServer ShareBookClient 小程序前端 showImg(https://seg...
摘要:簡介是阿里巴巴公司開源的一個高性能優(yōu)秀的服務(wù)框架,使得應(yīng)用可通過高性能的實(shí)現(xiàn)服務(wù)的輸出和輸入功能,可以和框架無縫集成。它提供了三大核心能力面向接口的遠(yuǎn)程方法調(diào)用智能容錯和負(fù)載均衡服務(wù)自動注冊和發(fā)現(xiàn)。首先我們需要前往官網(wǎng)下載安裝包。 Dubbo 簡介 Dubbo是阿里巴巴公司開源的一個高性能優(yōu)秀的服務(wù)框架,使得應(yīng)用可通過高性能的RPC實(shí)現(xiàn)服務(wù)的輸出和輸入功能,可以和Spring框架無縫集...
摘要:本章目標(biāo)基于項目搭建可以站外請求訪問的跨域資源服務(wù)器。允許所有的請求域名訪問我們的跨域資源,可以固定單條或者多條內(nèi)容,如,只有百度可以訪問我們的跨域資源。 CORS(Cross-Origin Resource Sharing)跨域資源共享,是一個W3C標(biāo)準(zhǔn),它允許瀏覽器向跨域服務(wù)器發(fā)送Ajax請求,打破了Ajax只能訪問本站內(nèi)的資源限制,CORS在很多地方都有被使用,微信支付的JS支付...
摘要:本章目的基于平臺整合分別完成客戶端服務(wù)端的單元測試。在測試控制器內(nèi)添加了三個測試方法,我們接下來開始編寫單元測試代碼??偨Y(jié)本章主要介紹了基于平臺的兩種單元測試方式,一種是在服務(wù)端采用注入方式將需要測試的或者注入到測試類中,然后調(diào)用方法即可。 單元測試對于開發(fā)人員來說是非常熟悉的,我們每天的工作也都是圍繞著開發(fā)與測試進(jìn)行的,在最早的時候測試都是采用工具Debug模式進(jìn)行調(diào)試程序,后來Ju...
摘要:一什么是摘自官網(wǎng)翻譯采納了建立生產(chǎn)就緒應(yīng)用程序的觀點(diǎn)。優(yōu)先于配置的慣例,旨在讓您盡快啟動和運(yùn)行。致力于簡潔,讓開發(fā)者寫更少的配置,程序能夠更快的運(yùn)行和啟動。二搭建第一個程序可以在上建項目,也可以用構(gòu)建。已經(jīng)凌晨了,我要睡了源碼 一.什么是spring boot Takes an opinionated view of building production-ready Spring a...
閱讀 1407·2021-11-08 13:14
閱讀 762·2021-09-23 11:31
閱讀 1052·2021-07-29 13:48
閱讀 2791·2019-08-29 12:29
閱讀 3387·2019-08-29 11:24
閱讀 1912·2019-08-26 12:02
閱讀 3709·2019-08-26 10:34
閱讀 3450·2019-08-23 17:07