Есть ли способ отправить только код ошибки, а не поле ошибки в Spring Validator?
У нас есть весенний веб-сервис RestFul, и для проверки параметра запроса мы используем валидатор Spring. Вот как выглядит мой валидатор:
@Override
public void validate( Object oObject, Errors oErrors )
{
RequestDAO oRequest = (RequestDAO) oObject;
if (Validation on FIELD 1 fails )
{
oErrors.rejectValue( "FIELD1", ERROR CODE );
}
else if ( If any other validation fails )
{
oErrors.rejectValue( "", A Different error code );
//I just want to send the ERROR CODE here and not the name of the filed
//IS it the correct way to do it?
}
}
В моем классе обработчика исключений я получаю ошибку проверки и генерирую свое собственное исключение:
protected AppException convertValidionErrorToCustomException( MethodArgumentNotValidException oMethodArgNotvalidExp ) {
CustomException oAppExp = null;
BindingResult oBindingResult = oMethodArgNotvalidExp.getBindingResult();
// Get the first error associated with a field, if any.
FieldError oFieldError = oBindingResult.getFieldError();
// IF I DONT SENT THE NAME OF THE FIELD I GET NULL ABOVE and thus an NP exp
String sCode = oFieldError.getCode();
if ( StringUtils.isEmpty( sCode ) || !StringUtils.isNumeric( sCode ) )
{
oAppExp = new CustomException( oMethodArgNotvalidExp );
}
else
{
int iErrorCode = Integer.parseInt( oFieldError.getCode() );
String sFieldName = oFieldError.getField();
if ( !StringUtils.isEmpty( sFieldName ) ) {
oAppExp = new CustomException( iErrorCode, sFieldName );
} else {
oAppExp = new CustomException( iErrorCode );
}
}
return oAppExp;
}
Мой вопрос: Как я могу отправить только код ошибки, а не Filed Name из класса Validator. Также Как изменить мой метод обработчика исключений для обработки следующего 2 сценария:
Когда отправляются имя поля и код ошибки
Когда отправляется только код ошибки, а не имя файла.
1 ответ
Я наконец нашел способ. Я обновил свой обработчик исключений, чтобы иметь это:
protected CustomException convertValidionErrorToAppException( MethodArgumentNotValidException oMethodArgNotvalidExp ) {
CustomException Exp = null;
BindingResult oBindingResult = oMethodArgNotvalidExp.getBindingResult();
// Get the first error associated with a field, if any.\
if ( oBindingResult.hasFieldErrors() ) {
Exp = processFieldError( oBindingResult, oMethodArgNotvalidExp );
} else {
Exp = processErrors( oBindingResult, oMethodArgNotvalidExp );
}
return Exp;
}
ProcessFieldError( oBindingResult, oMethodArgNotvalidExp); Метод обрабатывает все полевые ошибки, а processErrors (oBindingResult, oMethodArgNotvalidExp) обрабатывает неполевые ошибки. Метод выглядит так
protected CustomExceptionprocessErrors( BindingResult oBindingResult, MethodArgumentNotValidException oMethodArgNotvalidExp ) {
CustomException Exp = null;
//Get all errors from Binding Errors
ObjectError oError = oBindingResult.getAllErrors().get( 0 );
String sCode = oError.getCode();
if ( StringUtils.isEmpty( sCode ) || !StringUtils.isNumeric( sCode ) ) {
Exp = new CustomException( oMethodArgNotvalidExp );
} else {
int iErrorCode = Integer.parseInt( sCode );
Exp = new CustomException( iErrorCode );
}
return Exp;
}