SpringBoot使用jsr303校驗的實現(xiàn)
依賴添加
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-validation</artifactId> </dependency>
一些較老版本的SpringBoot需要添加相關(guān)依賴,我使用的2.1.4發(fā)行版不用這個操作。
驗證使用對象接收參數(shù)的情況
public class PointDeductSetRequest { private Long id; @NotBlank(message = "租戶id為空") private String tenantId; private Integer status; @NotNull private Integer pointValue; @NotNull private Integer deductValue; @NotBlank(message = "操作員id為空") private String operator; }
首先在需要驗證的對象的對應(yīng)字段上方加上校驗注解,以下為一些常用注解:
- @Null 限制只能為null
- @NotNull 限制必須不為null
- @AssertFalse 限制必須為false
- @AssertTrue 限制必須為true
- @DecimalMax(value) 限制必須為一個不大于指定值的數(shù)字
- @DecimalMin(value) 限制必須為一個不小于指定值的數(shù)字
- @Digits(integer,fraction) 限制必須為一個小數(shù),且整數(shù)部分的位數(shù)不能超過integer,小數(shù)部分的位數(shù)不能超過fraction
- @Future 限制必須是一個將來的日期
- @Max(value) 限制必須為一個不大于指定值的數(shù)字
- @Min(value) 限制必須為一個不小于指定值的數(shù)字
- @Past 限制必須是一個過去的日期
- @Pattern(value) 限制必須符合指定的正則表達式
- @Size(max,min) 限制字符長度必須在min到max之間
- @Past 驗證注解的元素值(日期類型)比當(dāng)前時間早
- @NotEmpty 驗證注解的元素值不為null且不為空(字符串長度不為0、集合大小不為0)
- @NotBlank 驗證注解的元素值不為空(不為null、去除首位空格后長度為0),不同于@NotEmpty,@NotBlank只應(yīng)用于字符串且在比較時會去除字符串的空格
- @Email 驗證注解的元素值是Email,也可以通過正則表達式和flag指定自定義的email格式
@RequestMapping(value = "/deduct", method = RequestMethod.POST) public BusinessResponse setPointDeduct(@RequestBody @Valid PointDeductSetRequest request){ pointDeductService.setPointDeductRule(request); return new BusinessResponse(ResponseEnum.OK); }
之后在controller方法的對象參數(shù)前加@Valid注解。
校驗使用單個參數(shù)接受的情況
@RequestMapping(value = "/deduct", method = RequestMethod.GET) public PageResponse<TPointDeduct> getPointDeductList(@RequestParam(value = "page", required = false) Integer page, @RequestParam(value = "pageSize", required = false) Integer pageSize, @RequestParam(value = "tenantId", required = false) @NotBlank(message = "租戶id為空") String tenantId, @RequestParam(value = "status", required = false) Integer status){ PageResponse<TPointDeduct> response = pointDeductService.getPointDeductList(page, pageSize, tenantId, status); response.setCodeMsg(ResponseEnum.OK); return response; }
首先需要在controller類上加@Validated注解,之后在方法中需要校驗的參數(shù)前加上對應(yīng)的校驗注解進行校驗。
對校驗產(chǎn)生的異常的捕獲
定義全局異常處理類并用@ControllerAdvice標(biāo)注,由于對象和單個參數(shù)因校驗產(chǎn)生的異常類型不同,因此需要分別處理。
對于對象作為接收前端請求的情況,因校驗產(chǎn)生的異常類型為MethodArgumentNotValidException,示例方法如下:
/** * 捕獲303對于body中的對象字段校驗 * @param e * @param request * @return */@ExceptionHandler(MethodArgumentNotValidException.class) @ResponseBody ResponseEntity<Object> handleMethodArgumentNotValidException(MethodArgumentNotValidException e, HttpServletRequest request){ List<FieldError> fieldErrors = e.getBindingResult().getFieldErrors(); if (fieldErrors != null && !fieldErrors.isEmpty()){ String message = fieldErrors.get(0).getDefaultMessage(); log.error(message, e); } HttpStatus httpStatus = HttpStatus.INTERNAL_SERVER_ERROR; HttpHeaders headers = new HttpHeaders(); Response response = new Response(); response.setCode(ResponseEnum.FORMAT_ERROR.code()); response.setMessage(ResponseEnum.FORMAT_ERROR.message()); return new ResponseEntity<>(response, headers, httpStatus); }
對于使用單個參數(shù)接受前端請求,因校驗產(chǎn)生的異常類為ConstraintViolationException,示例方法如下:
/** * 捕獲303對于request param單個參數(shù)的校驗 * @param e * @param request * @return */@ExceptionHandler(ConstraintViolationException.class) @ResponseBody ResponseEntity<Object> handleConstraintViolationException(ConstraintViolationException e, HttpServletRequest request){ HttpStatus httpStatus = HttpStatus.INTERNAL_SERVER_ERROR; HttpHeaders headers = new HttpHeaders(); Response response = new Response(); response.setCode(ResponseEnum.FORMAT_ERROR.code()); response.setMessage(ResponseEnum.FORMAT_ERROR.message()); return new ResponseEntity<>(response, headers, httpStatus); }
到此這篇關(guān)于SpringBoot使用jsr303校驗的實現(xiàn)的文章就介紹到這了,更多相關(guān)SpringBoot jsr303校驗內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MyBatis 三表外關(guān)聯(lián)查詢的實現(xiàn)(用戶、角色、權(quán)限)
這篇文章主要介紹了MyBatis 三表外關(guān)聯(lián)查詢的實現(xiàn)(用戶、角色、權(quán)限),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08SpringBoot+jpa配置如何根據(jù)實體類自動創(chuàng)建表
這篇文章主要介紹了SpringBoot+jpa配置如何根據(jù)實體類自動創(chuàng)建表,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11