我有一个非常天真的概念性问题来澄清。在我的应用我目前使用JSR 303 Hibernate验证确认与@NotBlank和@NotNull注解域模型,如检查用户名,密码等使用JSR-303验证器而不是Spring验证器
public class Admin {
private Long id;
@NotBlank(message = "Username should not be null")
private String username;
@NotBlank(message = "Username should not be null")
private String password;
...
但对于验证域逻辑类似现有的用户名,我“M仍然使用Spring的Validator接口
@Component
public class AdminValidator implements Validator {
...
@Override
public void validate(Object target, Errors errors) {
Admin admin = (Admin) target;
if (usernameAlradyExist())){
errors.rejectValue("username", null, "This user already exist's in the system.");
}
}
在控制器中,我同时使用
@RequestMapping(value = "/register", method = RequestMethod.POST)
public String register(@Valid @ModelAttribute("admin") Admin admin, BindingResult bindingResult,) {
validator.validate(admin, bindingResult);
if (bindingResult.hasErrors()) {
return REGISTER_ADMIN.getViewName();
}
是否可以只使用Hibernate的验证,而不是都使用Spring验证器验证域逻辑?
谢谢,那就是我一直在寻找的:-) – tintin 2012-07-08 10:28:56
@tintin:很高兴我能帮忙:) – xyz 2012-07-08 10:32:32