Docs

Documentation versions (currently viewingVaadin 7)

You are viewing documentation for an older Vaadin version. View latest documentation

Using Bean Validation to validate input

Before you get started with Bean Validation you need to download a Bean Validation implementation and add it to your project. You can find one for instance at https://bval.apache.org/downloads.html. Just add the jars from the lib folder to your project.

Bean Validation works as a normal validator. If you have a bean with Bean Validation annotations, such as:

Source code
Java
public class Person {

  @Size(min = 5, max = 50)
  private String name;

  @Min(0)
  @Max(100)
  private int age;
  // + constructor + setters + getters
}

You can create a field for the name field as you always would:

Source code
Java
Person person = new Person("John", 26);
BeanItem<Person> item = new BeanItem<Person>(person);

TextField firstName = new TextField("First name",
        item.getItemProperty("name"));
firstName.setImmediate(true);
setContent(firstName);

and add the bean validation as a normal validator:

Source code
Java
firstName.addValidator(new BeanValidator(Person.class, "name"));

Your firstName field is now automatically validated based on the annotations in your bean class. You can do the same thing for the age field and you won’t be able to set a value outside the valid 0-100 range.

A Bean Validation tutorial is available here: https://docs.oracle.com/javaee/6/tutorial/doc/gircz.html