验证日期间隔的重叠,在验证器类的实现中。我从 Posgresql 数据库中获取了一个列表,我想在错误消息旁边显示该列表。
我试图用这行代码插入它,但没有成功:
model.addAttribute("dateOverlaps", pricesValidator.getDBIntervals());
这是完整的代码:
@Controller
public class PricesController {
@Autowired
private RateRepository rateRepository;
@Autowired
private PricesValidator pricesValidator;
@InitBinder
protected void initBinder(WebDataBinder binder) {
binder.addValidators(pricesValidator);
}
//Enter new price form
@GetMapping("/admin/rates/priceform")
public String priceForm(Model model){
model.addAttribute("rate", new Rate());
model.addAttribute("dateOverlaps", pricesValidator.getDBIntervals());
return "/admin/rates/priceform";
}
@PostMapping("/admin/rates/priceform")
public String priceSubmit(@ModelAttribute @Valid Rate price, BindingResult bindingResult){
if(bindingResult.hasErrors()){
return "/admin/rates/priceform";
}
rateRepository.addRate(price);
return "redirect:/admin/rates/prices";
}
}
我使用百里香叶,但我理所当然地认为问题不在于观众。
这是 html 视图:
<!--Global validation results-->
<div th:if="${#fields.hasErrors('global')}">
<div class="alert alert-danger" role="alert"
th:each="err : ${#fields.errors('global')}">
<div th:switch="${err}">
<p th:case="error.fromAfterTo" th:text="#error.fromAfterTo}"></p>
<p th:case="error.overlaps" th:text="#{error.overlaps}"></p>
<ul>
<li th:text="#{from} + ' - ' + #{to}"></li>
<li th:each="interval : ${dateOverlaps}"
th:text="${#temporals.format(interval.datefrom, 'dd/MM/yyyy')} + '-' +
${#temporals.format(interval.dateto, 'dd/MM/yyyy')}">Intervals</li>
</ul>
</div>
</div>
</div><!--Global validation results-->
提前感谢您的帮助。
问题是 pricesValidator.getDBIntervals(( 在 @GetMapping:
model.addAttribute("dateOverlaps", pricesValidator.getDBIntervals());
正在调用我要显示的消息错误列表,该列表在提交表单之前为空。因为它的值是通过验证过程从数据库中获取的。
这就提出了一个新问题:
如何在@PostMapping部分中设置此模型属性?
这个问题的答案很简单,在@PostMapping部分中,您可以设置模型,也可以在@GetMapping模型中设置模型。就我而言,这是解决方案:
@PostMapping("/admin/rates/priceform")
public String priceSubmit(@ModelAttribute @Valid Rate price, BindingResult bindingResult, Model model){
if(bindingResult.hasErrors()){
model.addAttribute("dateOverlaps", pricesValidator.getDBIntervals());
return "/admin/rates/priceform";
}
rateRepository.addRate(price);
return "redirect:/admin/rates/prices";
}