Вопрос по jpa-2.0, jpa, bean-validation – Нарушены ограничения проверки подлинности bean при выполнении автоматической проверки bean для события обратного вызова: 'prePersist'

16

Я хотел бы хранитьbirthdate поэтому я выбралdate в MySQL, когда я создаю свои сущности на основе моей базы данных, получается так:

import java.util.Date;

    // ..code
    @NotNull(message="fill you birthdate")
    @Temporal(TemporalType.DATE)
    private Date birthdate;

Но когда я пытаюсь упорствовать, это дает мне эту ошибку:

Bean Validation constraint(s) violated while executing Automatic Bean Validation on callback event:'prePersist'. Please refer to embedded ConstraintViolations for details.

Что я здесь не так делаю? Я читал что-то об определении часового пояса в Google, я из Бразилии, как мне это сделать?

EDIT

package entity;

import java.io.Serializable;
import javax.persistence.*;
import javax.validation.constraints.NotNull;
import javax.validation.constraints.Size;

import org.hibernate.validator.constraints.Email;

import java.util.Date;
import java.util.List;


/**
 * The persistent class for the user database table.
 * 
 */
@Entity
public class User implements Serializable {
    private static final long serialVersionUID = 1L;

    @Id
    @GeneratedValue(strategy=GenerationType.IDENTITY)
    private Integer id;

    @Temporal(TemporalType.DATE)
    private Date birthdate;

    @NotNull(message="informe seu e-mail")
    @Email(message="e-mail inválido")
    private String email;

    @NotNull(message="informe seu gênero")
    private String gender;

    private String image;

    @NotNull(message="informe seu nome completo")
    private String name;

    @Size(min=6,max=16, message="senha com no mínimo: 6 dígitos e no máximo 16 dígitos")
    @NotNull(message="informe sua senha")
    private String password;

    //bi-directional many-to-one association to Document
    @OneToMany(mappedBy="user")
    private List<Document> documents;

    //bi-directional many-to-one association to QuestionQuery
    @OneToMany(mappedBy="user")
    private List<QuestionQuery> questionQueries;

    //bi-directional many-to-one association to Team
    @OneToMany(mappedBy="user")
    private List<Team> teams;

    public User() {
    }

    public Integer getId() {
        return this.id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public Date getBirthdate() {
        return this.birthdate;
    }

    public void setBirthdate(Date birthdate) {
        this.birthdate = birthdate;
    }

    public String getEmail() {
        return this.email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    public String getGender() {
        return this.gender;
    }

    public void setGender(String gender) {
        this.gender = gender;
    }

    public String getImage() {
        return this.image;
    }

    public void setImage(String image) {
        this.image = image;
    }

    public String getName() {
        return this.name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getPassword() {
        return this.password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public List<Document> getDocuments() {
        return this.documents;
    }

    public void setDocuments(List<Document> documents) {
        this.documents = documents;
    }

    public List<QuestionQuery> getQuestionQueries() {
        return this.questionQueries;
    }

    public void setQuestionQueries(List<QuestionQuery> questionQueries) {
        this.questionQueries = questionQueries;
    }

    public List<Team> getTeams() {
        return this.teams;
    }

    public void setTeams(List<Team> teams) {
        this.teams = teams;
    }

    public void print() {
        System.out.println("User [id=" + id + ", birthdate=" + birthdate + ", email="
                + email + ", gender=" + gender + ", image=" + image + ", name="
                + name + ", password=" + password + "]");
    }



}
Это первичный ключ? Swarne27
это очень досадное исключение, потому что у меня никогда не было проблем сDate до.. Valter Silva
@ Martin нет, у меня его нет. Valter Silva
у вас есть @PrePersist в вашем коде сущности? Если это так, пожалуйста, вставьте его также Marthin
Это довольно общая ошибка, она может возникать из-за ошибок проверки в каком-либо другом поле вашей модели. Мой обычный подход: включить SQL и ведение журнала параметров (легко для EclipseLink, но я думаю, что большинство поставщиков JPA поддерживают его) или выполнить попытку / пойматьem.flush() (для принудительной фиксации вместо ожидания выполнения контейнера) и зацикливание ConstraintViolations, чтобы найти проблему. Cascader

Ваш Ответ

7   ответов
13

Я получил быстрый способ, поймать следующее исключение, когда вы сохраняете сущность. В моем случае это метод EJB add. где я делаюem.persist(), Затем проверьте журнал сервера, вы увидите, какой атрибут имеет ограничение ограничения.

catch (ConstraintViolationException e) {
       log.log(Level.SEVERE,"Exception: ");
       e.getConstraintViolations().forEach(err->log.log(Level.SEVERE,err.toString()));
    }
Спасибо, это работает!
нет проблем. Удачного кодирования.
30

У меня возникла та же проблема, но после того, как я часами искал ответ, Наконец-то я ее нашел .... Вам нужно отредактировать свойAbstractFacade.java класс и добавить этот код

public void create(T entity) {

    ValidatorFactory factory = Validation.buildDefaultValidatorFactory();
    Validator validator = factory.getValidator();
    Set<ConstraintViolation<T>> constraintViolations = validator.validate(entity);
    if(constraintViolations.size() > 0){
        Iterator<ConstraintViolation<T>> iterator = constraintViolations.iterator();
        while(iterator.hasNext()){
            ConstraintViolation<T> cv = iterator.next();
            System.err.println(cv.getRootBeanClass().getName()+"."+cv.getPropertyPath() + " " +cv.getMessage());

            JsfUtil.addErrorMessage(cv.getRootBeanClass().getSimpleName()+"."+cv.getPropertyPath() + " " +cv.getMessage());
        }
    }else{
        getEntityManager().persist(entity);
    }
}

Теперь этот метод предупредит вас, какое свойство и почему оно не проходит проверку. Я надеюсь, что это работает для вас, как и для меня.

это должен быть принятый ответ!
Где я могу найти класс AbstractFacade.java? Должен ли я сделать новый класс?
4

Конечно, ответ Iomanip полностью верен! Я только что немного его расширил. Может быть, это тоже помогает:

  private boolean constraintValidationsDetected(T entity) {
    ValidatorFactory factory = Validation.buildDefaultValidatorFactory();
    Validator validator = factory.getValidator();
    Set<ConstraintViolation<T>> constraintViolations = validator.validate(entity);
    if (constraintViolations.size() > 0) {
      Iterator<ConstraintViolation<T>> iterator = constraintViolations.iterator();
      while (iterator.hasNext()) {
        ConstraintViolation<T> cv = iterator.next();
        System.err.println(cv.getRootBeanClass().getName() + "." + cv.getPropertyPath() + " " + cv.getMessage());

        JsfUtil.addErrorMessage(cv.getRootBeanClass().getSimpleName() + "." + cv.getPropertyPath() + " " + cv.getMessage());
      }
      return true;
    }
    else {
      return false;
    }
  }

  public void create(T entity) {
    if (!constraintValidationsDetected(entity)) {
      getEntityManager().persist(entity);
    }
  }

  public T edit(T entity) {
    if (!constraintValidationsDetected(entity)) {
      return getEntityManager().merge(entity);
    }
    else {
      return entity;
    }
  }

  public void remove(T entity) {
    if (!constraintValidationsDetected(entity)) {
      getEntityManager().remove(getEntityManager().merge(entity));
    }
  }
Спасибо за код, он работает отлично. Я предполагаю, что в названии метода есть опечатка:constraintValidationsDetected - & GT;constraintViolationsDetected
Работает нормально, пока не придется удалять. Это вызывает StackOverflowError в цикле между слиянием и удалением. Мне пришлось отключить метод удаления, чтобы он работал.
1

Я потратил несколько часов на борьбу с этой ошибкой, пытаясь сохранить сущность.

Bean Validation constraint(s) violated while executing Automatic Bean Validation on callback event:'preUpdate'. Please refer to embedded ConstraintViolations for details.

Это сообщение об ошибке не полезно, довольно запутанно ...

В любом случае в моем случае причина ошибки была - разница между аннотациями в Enity

@Size(min = 1, max = 10)
@Column(name = Utilizator.JPA_DISCRIMINATOR)
private String jpaDiscriminator;

И определение столбца базы данных:

jpaDiscriminator VARCHAR (15) НЕ NULL,

5

Ошибка показывает, что сущность, которую вы пытаетесь сохранить, не работает ограничения базы данных, поэтому попробуйте определить точные значения, которые вы вставляете в базу данных перед тем, как вставлять.

и попробуйте, комментируя / пропуская@NotNull аннотация тоже.

Вот как я пишу свою форму в базе данных:User [id=null, birthdate=Sun Sep 29 21:00:00 BRT 1985, [email protected], gender=M, image=null, name=valter, password=afSQtkcfmikK2G7CLfcL4RJewIGB10oe Valter Silva
если ваш первичный ключ - id, почему вы установили его в null?
Идентификатор не может быть нулевым. Попробуйте выяснить, почему он нулевой?
все еще с тем же исключением Valter Silva
Какой у вас первичный ключ?
5

То, что я сделал, чтобы решить мою проблему, было инвертировать заказ@Size а также@NotNull

до:

@Size(min=6,max=16, message="senha com no mínimo: 6 dígitos e no máximo 16 dígitos")
@NotNull(message="informe sua senha")
private String password;

после:

@NotNull(message="informe sua senha")
@Size(min=6,max=16, message="senha com no mínimo: 6 dígitos e no máximo 16 dígitos")
private String password;

Я не знаю, почему этот порядок так важен, но он имеет значение =] Всем спасибо!

Я только столкнулся с той же проблемой, и этот пост помог мне! Я решил это убрав@NotNull и положиnullable = false в@Column.
Это не правильный ответ.
2

У меня была похожая проблема. В моем случае размеры указанных PK и FK различались (см. Пример).

Сущность A:

some_pk   INTEGER NOT NULL,
fk_b      VARCHAR2(5 CHAR)
...

fk_b ссылается на поле идентификатора объекта B

Сущность B:

id VARCHAR2(4 CHAR)
...

Ид был здесь PK.

Обратите внимание на размеры ID (4) и FK_B (5). После изменения идентификатора B на5 CHAR ошибка ушла.

Похожие вопросы