我在控制器中注册了两个验证器。问题是-InvoiceFormValidator可以正常工作,如果有错误,则返回错误,然后重定向到所需的页面,并用数据填充表单。
第二个根本不重定向,它只是将我重定向到错误页面,向我显示:
Date Thu Apr 25 15:22:57 CEST 2019 Path / contractor / update / 5cc193e581c7dc75cfb7bcff错误错误的请求状态 对象=“承包商”的400消息验证失败。错误计数: 1
现在的代码:(我仅介绍代码的重要部分)
@Autowired private InvoiceFormValidator invoiceFormValidator;
@Autowired private PersonFormValidator personFormValidator;
@InitBinder({"invoicedata"})
protected void initPersonFormBinder(WebDataBinder binder) {
binder.addValidators(invoiceFormValidator);
}
@InitBinder({"contractor"})
protected void initContractorFormBinder(WebDataBinder binder) {
binder.addValidators(personFormValidator);
}
这是控制器端的外观(对于initPersonFormBinder
:)
@RequestMapping(value = "/addinvoice", method = RequestMethod.POST, produces = MediaType.APPLICATION_FORM_URLENCODED_VALUE)
public String addInvoice(@CurrentUser Contractor contractor, @ModelAttribute("invoicedata") @Validated InvoiceData invoicedata, BindingResult result, Model model, RedirectAttributes attr) {
if (result.hasErrors()) {
return "add";
} else {
对于initContractorFormBinder
:
@RequestMapping(value = "/contractor/update/{id}", method = RequestMethod.POST, produces = MediaType.APPLICATION_FORM_URLENCODED_VALUE)
public String updateContractor(@PathVariable("id") String id, @ModelAttribute("contractor") @Validated Contractor contractor, Model model, BindingResult result, RedirectAttributes attr) {
if (result.hasErrors()) {
logger.error("BINDING RESULT ERROR");
return "index";
} else {
这里的问题是代码永远不会进入此方法,永远不会到达if
语句。
现在InvoiceFormValidator的代码端:
@Component
public class InvoiceFormValidator implements Validator {
Logger logger = LoggerFactory.getLogger(InvoiceFormValidator.class);
@Override
public boolean supports(Class<?> clazz) {
return InvoiceData.class.equals(clazz);
}
@Override
public void validate(Object target, Errors errors) {
ValidationUtils.rejectIfEmpty(errors, "receptionDate", "empty");
ValidationUtils.rejectIfEmpty(errors, "orderDate", "empty");
ValidationUtils.rejectIfEmpty(errors, "invoiceIssueDate", "empty");
ValidationUtils.rejectIfEmpty(errors, "contractDate", "empty");
ValidationUtils.rejectIfEmpty(errors, "invoiceNumber", "empty");
}
}
同时,PersonFormValidator看起来像这样:
@Component
public class PersonFormValidator implements Validator {
Logger logger = LoggerFactory.getLogger(com.look4app.generator.component.impl.PersonFormValidator.class);
@Override
public boolean supports(Class<?> clazz) {
return Contractor.class.equals(clazz);
}
@Override
public void validate(Object target, Errors errors) {
Contractor contractor = (Contractor) target;
if (contractor.getContractorData().getNip() == null || contractor.getContractorData().getNip().equals("")) {
errors.rejectValue("contractorData.nip", "empty");
}
logger.error("CONTRACTOR VALIDATION ERROR");
}
}
这里还有Thymeleaf模板的一小部分,用于不起作用的部分:
<form action="#" th:action="@{/contractor/update/{id}(id=${contractor.id})}" th:object="${contractor}" method="post">
<ul class="form-style-1">
<li>
<label>NIP<span class="required">*</span></label>
<input type="text" th:field="*{contractorData.nip}" id="nip" th:value="${contractor.contractorData?.nip}" >
<span class="error" th:if="${#fields.hasErrors('contractorData.nip')}" th:errors="*{contractorData.nip}">Generic error</span>
</li>
<li>
<input type="submit" value="Zapisz dane firmy" />
</li>
用于工作验证的相同HTML有所不同,但差别不大:
<form action="#" th:action="@{addinvoice}" th:object="${invoicedata}" method="post">
<ul class="form-style-1">
<li>
<label>Komentarz</label>
<input type="text" th:field="*{contractorComment}" id="contractorComment">
</li>
<li>
<input type="submit" value="Zapisz protokół" />
</li>
此重定向有什么问题?
答案 0 :(得分:1)
请注意方法参数顺序的细微差别:
public String addInvoice (... @ModelAttribute("invoicedata") @Validated InvoiceData invoicedata, BindingResult result, Model model, ...) {
public String updateContractor(... @ModelAttribute("contractor") @Validated Contractor contractor, Model model, BindingResult result, ...) {
BindingResult
参数应该紧跟在带有@Validated
的参数之后。如果您将方法签名更改为:
public String updateContractor(@PathVariable("id") String id, @ModelAttribute("contractor") @Validated Contractor contractor, BindingResult result, Model model, RedirectAttributes attr) {
您应该能够访问您的方法。如果BindingResult
之后直接在{em> 之后出现@ModelAttribute
参数,Spring会将验证结果放入BindingResult
并调用该方法,您可以在其中处理{{ 1}}。否则,Spring将处理验证并跳过该方法。