前提・実現したいこと
既存のデータを編集する入力フォームがあり、データベースから取得した値がテキストボックスに入力されています。
この入力された値変更して更新実行すると、入力データをバリデーションして入力規則違反があれば元のページにリダイレクトし、
エラーメッセージを表示させたいのですが、modelにエラー結果が存在することを確認できてもThymeleafのテンプレート側が認識されずに
エラーメッセージが表示されません。
コードはこちらの方法を参考にいたしました。
https://qiita.com/unhurried/items/de32dfe5c87643491e54
発生している問題・エラーメッセージ
エラーメッセージ
該当のソースコード
java
1@RequestMapping(value = "/list/edit", method = RequestMethod.GET) 2 public String edit(@RequestParam(name="id",required = false) String Id, 3 RedirectAttributes redirect,Model model) { 4 5 MyForm form = myFormService.getData(Id); 6 7 //確認用メッセージ 8 System.out.println(ClassUtils.getShortName(MyForm.class)); 9 System.out.println(model.containsAttribute("org.springframework.validation.BindingResult.myForm")); 10 11 if(!model.containsAttribute("myForm")) { 12 MyForm myForm = form; 13 model.addAttribute("myForm",myForm); 14 } 15 16 if(form == null) { 17 //一覧へ 18 redirect.addFlashAttribute("message",m.getMessage("nothing",null,Locale.JAPAN)); 19 return "redirect:"; 20 } 21 22 return "edit"; 23 }
java
1 @RequestMapping(value = "/list/update", method = RequestMethod.POST) 2 public String update(@ModelAttribute("myForm") @Validated 3 MyForm myForm ,BindingResult result,RedirectAttributes redirect, Model model) { 4 5 6 //入力内容が正しくないとき 7 if (result.hasErrors()) { 8 9 redirect.addFlashAttribute("myForm",myForm); 10 redirect.addFlashAttribute("error",m.getMessage("fail",null,Locale.JAPAN)); 11 redirect.addFlashAttribute(BindingResult.MODEL_KEY_PREFIX + Conventions.getVariableName(myForm), result); 12 13 //確認用 14 System.out.println(BindingResult.MODEL_KEY_PREFIX + Conventions.getVariableName(myForm)); 15 System.out.println(result); 16 17 return "redirect:edit?id="+myForm.getId(); 18 19 } 20 21 22 myFormService.update(myFrom.getName()); 23 24 25 redirect.addFlashAttribute("message",m.getMessage("success",null,Locale.JAPAN)); 26 27 return "redirect:edit?id="+myForm.getId(); 28 }
html
1 2 <form th:action="update" th:object="${myForm}" > 3 <p th:if="${#fields.hasErrors('name')}" th:errors="*{name}" style="color: red"></p> 4 <input th:field="*{name}"> 5 <input type="submit" name="" value="更新"> 6 </form>
あなたの回答
tips
プレビュー