SpringBoot集成validation校驗參數(shù)遇到的坑
公眾號中分享了一篇文章,關(guān)于SpringBoot集成validation校驗參數(shù)的,粉絲留言說有坑。
原留言如下:
有坑,你試試^A-\\d{12}-\\d{4}$,這條正則經(jīng)過validate這個方法無論參數(shù)寫的對不對都會報驗證錯誤,而用main方法測試是正常的。。
話說,針對這種回復(fù)我是不太信了,直覺告訴我,肯定是這位粉絲用錯了。但既然粉絲有疑問還是需要專門寫一個demo來驗證一下的。說寫就寫。
SpringBoot集成validation
集成過程非常簡單,在原項目的pom文件中直接引入如下依賴:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-validation</artifactId> </dependency>
引入之后,便可以在項目中使用@Valid等來進行校驗了。
這里寫一個簡單的示例基于@Valid來驗證提交的參數(shù)是否合法。首先建一個實體類,LoginForm(使用了Lombok):
@Data public class LoginForm { @NotBlank(message = "郵箱不能為空") @Email private String email; @NotBlank(message = "密碼不能為空") @Length(min = 6,message = "密碼長度最小為6位") private String password; @NotBlank @Pattern(regexp = "^A-\\d{12}-\\d{4}$",message = "格式錯誤") private String other; }
順便校驗了一下其他的參數(shù),最后一個other字段用來校驗粉絲提出疑問的正則表達式。
然后,在創(chuàng)建一個Controller類:
@Slf4j @RestController public class LoginController { @PostMapping("/login") public void login(@Valid LoginForm loginForm, BindingResult bindingResult) { log.info("loginForm:{}", loginForm); if (bindingResult.hasErrors()) { for (ObjectError error : bindingResult.getAllErrors()) { log.info("error:{}", error.getDefaultMessage()); } } else { log.info("參數(shù)校驗成功!"); } } }
如果參數(shù)校驗出錯,會打印錯誤日志,如果校驗成功則打印“參數(shù)校驗成功!”。因為是Post請求,咱們就寫一個針對該服務(wù)的單元測試:
@Slf4j @SpringBootTest @RunWith(SpringRunner.class) @AutoConfigureMockMvc @WebAppConfiguration public class TestLoginController { @Autowired private WebApplicationContext webApplicationContext; @Autowired private MockMvc mockMvc; @Before public void setUp() { mockMvc = MockMvcBuilders.webAppContextSetup(webApplicationContext).build(); } @Test public void testLogin() throws Exception { MvcResult mvcResult = mockMvc.perform(MockMvcRequestBuilders.post("/login") .param("email", "541075754@qq.com") .param("password", "123456") .param("other", "A-123456789012-1234") .accept(MediaType.APPLICATION_JSON)) .andDo(MockMvcResultHandlers.print()) .andReturn(); int status = mvcResult.getResponse().getStatus(); //得到返回代碼 String content = mvcResult.getResponse().getContentAsString(); //得到返回結(jié)果 log.info("返回結(jié)果content={}", content); Assert.assertEquals(200, status); } }
執(zhí)行打印測試,查看日志,發(fā)現(xiàn)校驗通過,并沒有出錯。至此,粉絲提出的質(zhì)疑并不成立。而粉絲遇到的問題,很可能是哪個細(xì)節(jié)導(dǎo)致了校驗失敗,而他總結(jié)的經(jīng)驗就是validation校驗參數(shù)有坑。
到此這篇關(guān)于SpringBoot集成validation校驗參數(shù)遇到的坑的文章就介紹到這了,更多相關(guān)SpringBoot集成validation校驗參數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot使用validation-api實現(xiàn)參數(shù)校驗的示例
- SpringBoot集成Validation參數(shù)校驗
- SpringBoot使用validation做參數(shù)校驗說明
- SpringBoot?中使用?Validation?校驗參數(shù)的方法詳解
- SpringBoot利用validation實現(xiàn)優(yōu)雅的校驗參數(shù)
- SpringBoot?Validation提示信息國際化配置方式
- SpringBoot使用Validation進行參數(shù)校驗的示例詳解
- springboot中使用Hibernate-Validation校驗參數(shù)詳解
- SpringBoot使用Validation校驗參數(shù)的詳細(xì)過程
- SpringBoot Validation入?yún)⑿r瀲H化的項目實踐
相關(guān)文章
Java基礎(chǔ)之SpringBoot整合knife4j
Swagger現(xiàn)在已經(jīng)成了最流行的接口文檔生成與管理工具,但是你是否在用的時候也在吐槽,它是真的不好看,接口測試的json數(shù)據(jù)沒法格式化,測試地址如果更改了還要去改配置,接口測試時增加token驗證是真的麻煩…針對Swagger的種種缺點,Knife4j就呼之欲出了.需要的朋友可以參考下2021-05-05Java五種方式實現(xiàn)多線程循環(huán)打印問題
本文主要介紹了Java五種方式實現(xiàn)多線程循環(huán)打印問題,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-12-12java并發(fā)編程之深入理解Synchronized的使用
文詳細(xì)講述了線程、進程的關(guān)系及在操作系統(tǒng)中的表現(xiàn),這是多線程學(xué)習(xí)必須了解的基礎(chǔ)。本文將接著講一下Java線程同步中的一個重要的概念synchronized,希望能夠給你有所幫助2021-06-06