JSR 303 Bean Validation - Why on getter and not setter?

前端 未结 4 1634
广开言路
广开言路 2020-12-29 20:25

I don\'t understand why JSR 303 (bean validation) is for the getter methods and not setter? Isn\'t it more logical to put it under setter method since that is the entry poin

相关标签:
4条回答
  • 2020-12-29 20:49

    Its a very good question and something that I have never paid attention to. But I think I know the answer ( and also why I never got this question myself).

    If you are looking at this, from the point of view that, the annotation defines where the validation will happen, then putting it on getter does not make sense. ( why not validate while storing the value itself..). But this is not how it works...

    The programmer needs to tell the validation framework, which properties needs to be validated. So you can put the annotation directly on the attribute (which I prefer) or you can put it on the getter. Both of them signify read operation. The Framework needs to read all the attributes of your class, that will have to be validated. So in this case, putting on setter makes no sense at all.. The key to understand is the perspective...

    I hope it makes sense.

    0 讨论(0)
  • 2020-12-29 20:58

    Bean Validation is called that way for a reason. It is applied to an initialized bean. So, first off, you initialize it with everything you have, then you pass it(or it is passed explicitly) to the Bean Validation implementation, which will rely on the validation annotations when accessing the fields. In case of Spring MVC validation handling starts at:

    result = execVal.validateParameters(
                    invocation.getThis(), methodToValidate, invocation.getArguments(), groups);
    

    inside MethodValidationInterceptor. From here on, it's passed to validation implementation, in most cases Hibernate. invocation.getArguments() will contain all the method arguments already initialized with the given values, regardless of validation annotations.

    0 讨论(0)
  • 2020-12-29 21:00

    Consider this code:

    public class BeanValidation {
    
        private int nameSetCount = 0;
        private int nameGetCount = 0;
        private String name;
    
        public String getName() {
            this.nameGetCount++;
            return name;
        }
    
        public void setName(String name) {
            this.nameSetCount++;
            this.name = name;
        }
    
    }
    

    Put annotation over private String name;

    Annotation identifies field easily just looking at the field.

    Put annotation over public String getName()

    Annotation identifies field easily just looking at the returned field.

    Put annotation over public void setName(String name)

    Annotation can not identify field looking at the modified field because there can be more than one.

    0 讨论(0)
  • 2020-12-29 21:11

    Annotating getters doesn't mean that validation is performed when a getter is invoked. It is just used to identify the property to which a constraint shall apply.

    The big advantage of putting constraints on (usually public) getters instead on (typically private) fields is that the constraints are part of the type's public API that way. They will even be added to the generated JavaDoc. A user of a type knows that way which constraints apply to it without looking into its internal implementation.

    Another advantage of annotating getters is that constraints can be put at methods on base classes or interfaces and also apply for any sub-types/implementations.

    0 讨论(0)
提交回复
热议问题