在Validator类的实现中验证日期间隔的重叠。我从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";
}
}
我使用的是Thymeleaf,但我认为问题不在于观众。
这是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-->
提前感谢您的帮助。
答案 0 :(得分:0)
问题是@GetMapping上的priceValidator.getDBIntervals():
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";
}