如何使用 javax 验证来验证 java 普通方法
How to validate java plain methods using javax validation
我正在使用 spring-boot-starter-validation
.
验证 java beans
控制器上的验证工作正常,
我想知道我们是否可以使用@Valid 注释来验证class 的正常方法?我已经试过了,但没有用。
我在控制器上的工作解决方案
@PostMapping("/testMessage")
ResponseEntity<String> testMethod(@Valid @RequestBody InternalMsg internalMsg) {
return ResponseEntity.ok("Valid Message");
}
我想将验证移至 class 方法,这样当我点击 RestAPI 时,验证错误会在新方法中被捕获。
假设该方法是 validateMsg of class MsgValidator 并且我在控制器代码中调用此方法
@PostMapping("/testMessage")
ResponseEntity<String> testMethod(@RequestBody InternalMsg internalMsg) { // No @Valid here
MsgValidator msgValidator = new MsgValidator();
Boolean isValid = msgValidator.validateMsg(internalMsg);
// some other processings
return ResponseEntity.ok("Valid Message");
}
public class MsgValidator{
public boolean validateMsg(@Valid InteropMsg interopMsg){
return true;
}
@ResponseStatus(HttpStatus.OK)
@ExceptionHandler(MethodArgumentNotValidException.class)
public ResponseEntity<Ack> handleValidationExceptions(MethodArgumentNotValidException ex) {
StringBuilder errorMessages = new StringBuilder("");
ex.getBindingResult().getAllErrors().forEach((error) -> {
errorMessages.append(error.getDefaultMessage()).append(";");
});
log.error("Validation errors : "+errorMessages.toString());
return ResponseEntity.ok().body(ack);
}
}
public class InternalMsg implements Serializable {
@NotNull(message = "Msg Num is a required field")
private String msgNumber;
@NotNull(message = "Activity Name is a required field")
private String activityName;
}
这不起作用
请让我知道如何实现这个
下面是一个示例,说明如何使用 ValidatorFactory
获取 Validator
来执行验证,而不是使用 @Valid
注释。
InternalMsg internalMsg = new InternalMsg();
ValidatorFactory factory = Validation.buildDefaultValidatorFactory();
Validator validator = factory.getValidator();
Set<ConstraintViolation<InternalMsg>> validate = validator.validate(internalMsg);
查看此处了解更多详情 -> https://www.baeldung.com/javax-validation
以下只是一个片段,不一定是推荐的使用方式 ValidationFactory
我正在使用 spring-boot-starter-validation
.
控制器上的验证工作正常,
我想知道我们是否可以使用@Valid 注释来验证class 的正常方法?我已经试过了,但没有用。
我在控制器上的工作解决方案
@PostMapping("/testMessage")
ResponseEntity<String> testMethod(@Valid @RequestBody InternalMsg internalMsg) {
return ResponseEntity.ok("Valid Message");
}
我想将验证移至 class 方法,这样当我点击 RestAPI 时,验证错误会在新方法中被捕获。
假设该方法是 validateMsg of class MsgValidator 并且我在控制器代码中调用此方法
@PostMapping("/testMessage")
ResponseEntity<String> testMethod(@RequestBody InternalMsg internalMsg) { // No @Valid here
MsgValidator msgValidator = new MsgValidator();
Boolean isValid = msgValidator.validateMsg(internalMsg);
// some other processings
return ResponseEntity.ok("Valid Message");
}
public class MsgValidator{
public boolean validateMsg(@Valid InteropMsg interopMsg){
return true;
}
@ResponseStatus(HttpStatus.OK)
@ExceptionHandler(MethodArgumentNotValidException.class)
public ResponseEntity<Ack> handleValidationExceptions(MethodArgumentNotValidException ex) {
StringBuilder errorMessages = new StringBuilder("");
ex.getBindingResult().getAllErrors().forEach((error) -> {
errorMessages.append(error.getDefaultMessage()).append(";");
});
log.error("Validation errors : "+errorMessages.toString());
return ResponseEntity.ok().body(ack);
}
}
public class InternalMsg implements Serializable {
@NotNull(message = "Msg Num is a required field")
private String msgNumber;
@NotNull(message = "Activity Name is a required field")
private String activityName;
}
这不起作用 请让我知道如何实现这个
下面是一个示例,说明如何使用 ValidatorFactory
获取 Validator
来执行验证,而不是使用 @Valid
注释。
InternalMsg internalMsg = new InternalMsg();
ValidatorFactory factory = Validation.buildDefaultValidatorFactory();
Validator validator = factory.getValidator();
Set<ConstraintViolation<InternalMsg>> validate = validator.validate(internalMsg);
查看此处了解更多详情 -> https://www.baeldung.com/javax-validation
以下只是一个片段,不一定是推荐的使用方式 ValidationFactory