私は次のようにクラスレベルでBeanValidationを使用してJSF2.0を学習しようとしました。
ユーティリティ
@Singleton
public class MyUtility {
public boolean isValid(final String input) {
return (input != null) || (!input.trim().equals(""));
}
}
制約アノテーション
@Retention(RetentionPolicy.RUNTIME)
@Target({
ElementType.TYPE,
ElementType.ANNOTATION_TYPE,
ElementType.FIELD
})
@Constraint(validatedBy = Validator.class)
@Documented
public @interface Validatable {
String message() default "Validation is failure";
Class<?>[] groups() default {};
Class<? extends Payload>[] payload() default {};
}
制約バリデーター
public class Validator extends ConstraintValidator<Validatable, MyBean> {
//
//----> Try to inject the utility, but it cannot as null.
//
@Inject
private MyUtility myUtil;
public void initialize(ValidatableconstraintAnnotation) {
//nothing
}
public boolean isValid(final MyBean myBean,
final ConstraintValidatorContext constraintContext) {
if (myBean == null) {
return true;
}
//
//----> Null pointer exception here.
//
return this.myUtil.isValid(myBean.getName());
}
}
データBean
@Validatable
public class MyBean {
private String name;
//Getter and Setter here
}
JSFバッキングBean
@Named
@SessionScoped
public class Page1 {
//javax.validation.Validator
@Inject
private Validator validator;
@Inject
private MyBean myBean;
//Submit method
public void submit() {
Set<ConstraintViolation<Object>> violations =
this.validator.validate(this.myBean);
if (violations.size() > 0) {
//Handle error here.
}
}
}
java.lang.NullPointerException
実行後、行の「Validator」という名前のクラスのように例外に直面しましたreturn this.myUtil.isValid(myBean.getName());
。CDIがユーティリティインスタンスを挿入しないことを理解しています。私が間違っている場合は私を訂正してください。
何か間違ったことをしているのか、それともBean検証の制限なのかわかりません。さらに説明していただけませんか?