Как сервер проверяет каждую запись в списке, используя пользовательский валидатор - PullRequest
0 голосов
/ 05 апреля 2019

У меня есть приложение Springboot Rest с настраиваемым валидатором сервера для одной из моделей.Есть 2 конечных точки API, одна получает один объект, а другая получает список того же объекта.Мой пользовательский валидатор отлично работает на первой конечной точке.Как я могу использовать тот же валидатор для другой конечной точки.

Класс модели

@Entity
@Table(name=TABLE_MESSAGE, schema = SCHEMA)
public class Message implements java.io.Serializable {

    @Id @GeneratedValue(strategy=IDENTITY)
    @Column(name=COLUMN_ID, unique=true)
    private Long id;

    @Basic(optional = false)
    @Column(name = COLUMN_CREATETIMESTAMP, insertable = false, updatable = false)
    @Temporal(TemporalType.TIMESTAMP)
    private Date timestamp;

    @Column(name=COLUMN_MESSAGE_SENDERNAME)
    private String senderName;

    @Column(name=COLUMN_MESSAGE_SENDEREMAIL)
    private String senderEmail;

    @Column(name=COLUMN_MESSAGE_SUBJECT)
    private String subject;

    @Column(name=COLUMN_MESSAGE_BODY)
    private String body;
}

Класс DTO

public class MessageForm {

    private List<Message> messageList;

    public List<Message> getMessageList() {
        return messageList;
    }

    public void setMessageList(List<Message> messageList) {
        this.messageList = messageList;
    }
}

Пользовательский валидатор

@Component
public class MessageValidator implements Validator {

    @Override
    public boolean supports(Class<?> clazz) {
        return Message.class.equals(clazz);
    }

    @Override
    public void validate(Object target, Errors errors) {
        ValidationUtils.rejectIfEmpty(errors, "senderName", ERRORCODE_MESSAGE_SENDERNAME_EMPTY);
        ValidationUtils.rejectIfEmpty(errors, "senderEmail", ERRORCODE_MESSAGE_SENDEREMAIL_EMPTY);
        ValidationUtils.rejectIfEmpty(errors, "subject", ERRORCODE_MESSAGE_SUBJECT_EMPTY);
        ValidationUtils.rejectIfEmpty(errors, "body", ERRORCODE_MESSAGE_BODY_EMPTY);
        Message m = (Message) target;

        if (!m.getSenderName().trim().equalsIgnoreCase(EMPTY_STRING) && m.getSenderName().matches(REGEX_CONTAINS_NUMBER)) {
            errors.rejectValue("senderName", ERRORCODE_MESSAGE_SENDERNAME_INVALID);
        }
        if (!m.getSenderEmail().trim().equalsIgnoreCase(EMPTY_STRING) && !m.getSenderEmail().matches( REGEX_EMAIL)) {
            errors.rejectValue("senderEmail", ERRORCODE_MESSAGE_SENDEREMAIL_INVALID);
        }
    }
}

Контроллер

@RestController
public class MainSiteRestController
{
    @Autowired
    private MessageValidator messageValidator;

     @InitBinder("message")
     protected void initMessageBinder(WebDataBinder binder) {
       binder.addValidators(messageValidator);
     }

    // this works fine
    public ResponseForm saveMessage(@Valid @RequestBody Message message, BindingResult bindingResult) throws APIException {
        if (bindingResult.hasErrors()){
            throw new APIException(getErrorMesage(bindingResult.getAllErrors()));
        }
        return apiService.saveMessage(message);
    }

    // this is not working
    public ResponseForm saveAllMessage(@RequestBody MessageForm messageForm, Errors errors) throws APIException {
        // need to validate the complete list or particular indexed object here, tried below code but not working
        // messageValidator.validate(messageForm.getMessageList().get(0), errors);
        if(errors.hasErrors()) {
            throw new APIException(createErrorString(errors));
        }
        return apiService.saveAllMessage(messageForm);
    }
}

1 Ответ

1 голос
/ 11 июля 2019

Валидаторы Spring работают с одной формой, поэтому вам придется создать валидатор для списка dto.

...