Bir Varlık: varlık için
package org.ibp.soq;
public class MyEntity {
private String field1;
private String field2;
//..getters and setters
}
Validator:
package org.ibp.soq;
import org.springframework.stereotype.Component;
import org.springframework.validation.Errors;
import org.springframework.validation.Validator;
@Component
public class MyEntityValidator implements Validator {
@Override
public boolean supports(Class<?> clazz) {
return MyEntity.class.equals(clazz);
}
@Override
public void validate(Object target, Errors errors) {
MyEntity myEntity = (MyEntity) target;
// Logic to validate my entity
System.out.print(myEntity);
}
}
ve
dökme PUT yöntemi ile dinlenme kontrol: Aşağıdaki istek gövde ile bu kaynak için bir satış isteğinde
package org.ibp.soq;
import java.util.List;
import javax.validation.Valid;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.WebDataBinder;
import org.springframework.web.bind.annotation.InitBinder;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RequestMapping("/myEntity")
public class MyEntityRestResource {
@Autowired
private MyEntityValidator myEntityValidator;
@InitBinder
protected void initBinder(final WebDataBinder binder) {
binder.addValidators(this.myEntityValidator);
}
@RequestMapping(method = RequestMethod.PUT)
public void bulkCreate(@RequestBody @Valid List<MyEntity> myEntities) {
// Logic to bulk create entities here.
System.out.print(myEntities);
}
}
:
[
{
"field1": "AA",
"field2": "11"
},
{
"field1": "BB",
"field2": "22"
}
]
I elde hatadır:
"Invalid target for Validator [[email protected]]: [[email protected], [email protected]]"
MyEntityValidator
vALIDA, tek
MyEntity
doğrulama "destekler" değil çünkü
bu olduğunu anlayabiliriz ArrayList<MyEntity>
için. I istek gövdesinde tek MyEntity
nesne ve @RequestBody @Valid MyEntity myEntity
parametresi olan bir karşılık gelen kontrol cihazı yöntemi varsa
MyEntityValidator
mükemmel çalışır.
nasıl kullanmış doğrulayıcı kurulumu, MyEntity
's toplama doğrulama desteklemek için uzatılabilir ?
Teşekkürler! Bu yaklaşımı kesinlikle deneyeceğim. –
Use \ @ControllerAdvice, tüm denetleyicilere CollectionValidator uygulayacaktır. Tahsilat olmayan bir nesne üzerinde başka bir @ @ Valid ek açıklama varsa "java.lang.IllegalStateException: Validator için geçersiz hedef" özelliğine neden olur. –
Bunun yerine \ @ InitBinder ("attrName") kullanın veya initBinder'ı belirli bir denetleyicide yapın. –