日常開(kāi)發(fā)中,前端會(huì)對(duì)請(qǐng)求參數(shù)進(jìn)行校驗(yàn)饵较,為了保證請(qǐng)求參數(shù)的格式正確循诉,也需要在服務(wù)端做參數(shù)校驗(yàn)茄猫。
服務(wù)端參數(shù)校驗(yàn)用的是Hibernate-validator框架募疮,利用簡(jiǎn)單注解實(shí)現(xiàn)僻弹。
實(shí)體類(lèi)增加校驗(yàn)注解
這里以登錄為例進(jìn)行說(shuō)明:
public class LoginDto {
@NotNull
private String username;//賬號(hào)
@NotNull
@Length(min = 6, message = "密碼格式錯(cuò)誤")
private String password;//密碼
//set get省略
}
這一塊用的注解來(lái)實(shí)現(xiàn),比較簡(jiǎn)單他嚷,具體注解的使用說(shuō)明如下:
| @Null | 被注釋的元素必須為 null |
| @NotNull | 被注釋的元素必須不為 null |
| @AssertTrue | 被注釋的元素必須為 true |
| @AssertFalse | 被注釋的元素必須為 false |
| @Min(value) | 被注釋的元素必須是一個(gè)數(shù)字蹋绽,其值必須大于等于指定的最小值 |
| @Max(value) | 被注釋的元素必須是一個(gè)數(shù)字芭毙,其值必須小于等于指定的最大值 |
| @DecimalMin(value) | 被注釋的元素必須是一個(gè)數(shù)字,其值必須大于等于指定的最小值 |
| @DecimalMax(value) | 被注釋的元素必須是一個(gè)數(shù)字卸耘,其值必須小于等于指定的最大值 |
| @Size(max, min) | 被注釋的元素的大小必須在指定的范圍內(nèi) |
| @Digits (integer, fraction) | 被注釋的元素必須是一個(gè)數(shù)字退敦,其值必須在可接受的范圍內(nèi) |
| @Past | 被注釋的元素必須是一個(gè)過(guò)去的日期 |
| @Future | 被注釋的元素必須是一個(gè)將來(lái)的日期 |
| @Pattern(value) | 被注釋的元素必須符合指定的正則表達(dá)式 |
2. Hibernate Validator 附加的 constraint
| @Email | 被注釋的元素必須是電子郵箱地址 |
| @Length(min=, max=)
| 被注釋的字符串的大小必須在指定的范圍內(nèi) |
| @NotEmpty | 被注釋的字符串的必須非空 |
| @Range(min=, max=) | 被注釋的元素必須在合適的范圍內(nèi) |
| @NotBlank|被注釋的字符串的必須非空|
controller增加@valid注解
在需要校驗(yàn)的請(qǐng)求controller方法中,增加@valid注解蚣抗,校驗(yàn)要獲取的對(duì)象字段侈百,如下圖:
在controllerAdvice中增加參數(shù)校驗(yàn)異常的統(tǒng)一攔截
/**
* 攔截@Valid請(qǐng)求參數(shù)驗(yàn)證不通過(guò)的異常
*
* @param request request
* @param response response
* @param exception 驗(yàn)證不通過(guò)的異常
* @return 執(zhí)行結(jié)果
*/
@ExceptionHandler(MethodArgumentNotValidException.class)
@ResponseStatus(HttpStatus.BAD_REQUEST)
@ResponseBody
@Order(0)
public JsonResult handler(HttpServletRequest request, HttpServletResponse response, MethodArgumentNotValidException exception) {
logger.info("請(qǐng)求的參數(shù)不正確", exception);
logException(request);
String validation_message;
BindingResult bindingResult = exception.getBindingResult();
if (bindingResult != null && bindingResult.getFieldError() != null) {
validation_message = bindingResult.getFieldError().getDefaultMessage();
} else {
validation_message = exception.getMessage();
}
logger.info("參數(shù)錯(cuò)誤信息:" + validation_message);
return new JsonResult(false, GlobalReturnCode.PARAM_ERROR, validation_message);
}
這里有個(gè)@Order(0)注解,參數(shù)校驗(yàn)首先進(jìn)行做翰铡,后續(xù)再做默認(rèn)系統(tǒng)異常攔截例证。比如校驗(yàn)失敗提示如下圖: