質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

Thymeleaf

Thymeleaf(タイムリーフ)とは、Java用のテンプレートエンジンで、特定のフレームワークに依存せず使用することが可能です。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

Q&A

解決済

1回答

2309閲覧

【springMVC】ドロップダウンの選択肢で発生するtypeMismatchを解決したい

asahiko123

総合スコア43

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

Thymeleaf

Thymeleaf(タイムリーフ)とは、Java用のテンプレートエンジンで、特定のフレームワークに依存せず使用することが可能です。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

0グッド

0クリップ

投稿2021/07/26 06:00

前提・実現したいこと

個人制作ですが、SpringMVC,thymeleaf,JDBCTemplateを使って、基本的なCRUD機能をもつアプリを作りました。

そのアプリの情報入力画面でドロップダウンの選択肢を選ばせる項目があるのですが、そのドロップダウンがデフォルトで「選択してください」という文字列を表示しています。

イメージ説明

ドロップダウンの選択肢が選ばれた場合はobj.id(Integer)がvalueに入り問題ないのですが、
デフォルトの文字列が選択された場合は、Stringが取得された扱いになり
typeMismatchを発生させてしまいます(エラーその1)。

今回やりたいことは、このtypeMismatchが発生したときにエラーメッセージを表示し
もう一回入力をやり直させることです。

ちなみに、通常の選択肢はベータベースのテーブルから引っ張ってきてth:eachの形で表示しています。

発生している問題・エラーメッセージ

エラーその1

Field error in object 'stuffForm' on field 'stuffId': rejected value [選択してください]; codes [typeMismatch.stuffForm.stuffId,typeMismatch.stuffId,typeMismatch.int,typeMismatch]; arguments [org.springframework.context.support.DefaultMessageSourceResolvable: codes [stuffForm.stuffId,stuffId]; arguments []; default message [stuffId]]; default message [Failed to convert property value of type 'java.lang.String' to required type 'int' for property 'stuffId'; nested exception is java.lang.NumberFormatException: For input string: "選択してください"]]

エラーその2

This application has no explicit mapping for /error, so you are seeing this as a fallback. Mon Jul 26 13:58:14 JST 2021 There was an unexpected error (type=Internal Server Error, status=500). An error happened during template parsing (template: "class path resource [templates/DailyReportForm.html]") org.thymeleaf.exceptions.TemplateInputException: An error happened during template parsing (template: "class path resource [templates/DailyReportForm.html]") at org.thymeleaf.templateparser.markup.AbstractMarkupTemplateParser.parse(AbstractMarkupTemplateParser.java:241) at org.thymeleaf.templateparser.markup.AbstractMarkupTemplateParser.parseStandalone(AbstractMarkupTemplateParser.java:100) (中略) Caused by: org.attoparser.ParseException: Could not parse as expression: "${#fields.hasErrors('stuffId')" (template: "DailyReportForm" - line 69, col 12) at org.attoparser.MarkupParser.parseDocument(MarkupParser.java:393) at org.attoparser.MarkupParser.parse(MarkupParser.java:257) at org.thymeleaf.templateparser.markup.AbstractMarkupTemplateParser.parse(AbstractMarkupTemplateParser.java:230) ... 48 more Caused by: org.thymeleaf.exceptions.TemplateProcessingException: Could not parse as expression: "${#fields.hasErrors('stuffId')" (template: "DailyReportForm" - line 69, col 12)

該当のソースコード

HTML

1<!doctype html> 2<html xmlns:th="http://www.thymeleaf.org" 3 xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout"> 4(中略) 5<main role="main" class="container"> 6<div class="starter-template text-center py-5 px-3"> 7 <form method ="POST" th:action ="${dailyReportForm.newReport}? @{/main/report/insert}:@{/main/report/update}" th:object="${dailyReportForm}"> 8 <p th:if="${complete}" th:text="${complete}" class ="alert alert-primary" role ="alert"></p> 9 <p th:if="${output}" th:text="${output}" class="alert alert-primary" role="alert"></p> 10 <h1 th:text="${title}">Bootstrap スターターテンプレート</h1> 11 12 <div class="form-group"> 13 <label for="exampleFormControlSelect1">スタッフID</label> 14 <!-- 追加記述部分 <div th:if="${#fields.hasErrors('stuffId')" th:errors="*{stuffId}" class="alert alert-danger" role="alert"}></div>--> 15 <select class="form-select form-select-lg mb-3" aria-label=".form-select-lg example" name ="stuffId"> 16 <option>選択してください</option> 17 <option th:each ="obj:${stuff}" th:value ="${obj.id}"th:text ="${obj.registeredId}" ></option> 18 </select> 19 </div> 20 21 <div class="form-group"> 22 <label for="exampleFormControlSelect1">作業区分ID</label> 23 <!-- 追加記述部分 <div th:if="${#fields.hasErrors('workId')" th:errors="*{workId}" class="alert alert-danger" role="alert"}></div>--> 24 <select class="form-select form-select-lg mb-3" aria-label=".form-select-lg example" name="workId"> 25 <option>選択してください</option> 26 <option th:each ="obj:${work}" th:value ="${obj.id}"th:text ="${obj.workDivId}"></option> 27 </select> 28 </div> 29     (中略) 30          <div class="d-grid gap-2"> 31 <input th:if ="${dailyReportId}" type ="hidden" th:value ="${dailyReportId}" name ="dailyReportId"> 32 <button type="submit" class ="btn btn-primary">登録</button> 33 </div> 34 </body> 35</html> 36

ValidationMassages_ja.properties

#typeMismatch typeMismatch.java.lang.Integer ="{0}" must be an integer. #field name stuffId =stuffId workId = workId

Controllerクラス

package com.example.demo.app.dailyreport; import java.io.FileOutputStream; import java.io.IOException; (中略) @Controller @RequestMapping("/main") public class DailyReportController { private final DailyReportService dailyReportService; private int id; private String stuff; private String work; private String progress; private String date; private String start; private String end; private String detail; public DailyReportController(DailyReportService dailyReportService) { this.dailyReportService = dailyReportService; } @GetMapping public String top(Model model) { model.addAttribute("title","日報アプリ"); return"top"; } @GetMapping("/report") public String DailyReport(DailyReportForm dailyReportForm,Model model) { dailyReportForm.setNewReport(true); List<DailyReport> list = dailyReportService.findAll(); List<Stuff> stuff = dailyReportService.findStuff(); List<Work> work = dailyReportService.findWork(); model.addAttribute("list",list); model.addAttribute("stuff",stuff); model.addAttribute("work",work); model.addAttribute("title","日報入力"); return "DailyReportForm"; } (中略) @PostMapping("/report/insert") public String insert( @Valid@ModelAttribute DailyReportForm dailyReportForm, BindingResult result, StuffForm stuffForm, WorkForm workForm, Model model) { DailyReport dailyReport = makeDailyReport(dailyReportForm,0); if(!result.hasErrors()) { dailyReportService.insert(dailyReport); return "redirect:/main/report"; }else { dailyReportForm.setNewReport(true); model.addAttribute("DailyReportForm",dailyReportForm); List<DailyReport> list = dailyReportService.findAll(); List<Stuff> stuff = dailyReportService.findStuff(); List<Work> work = dailyReportService.findWork(); model.addAttribute("stuff",stuff); model.addAttribute("work",work); model.addAttribute("list",list); model.addAttribute("title","日報入力"); return"DailyReportForm"; } (中略) }

試したこと

・resourcesファイル直下にValidationMassages_ja.propertiesファイルを作成し、
htmlにth:if="${#fields.hasError('フィールド名')}から始まる一連のコードを記述しました。

しかし、この記述を入れるとエラーその2が発生し機能しません。
単純なテキスト入力項目で同じコードを記述したときは正常に機能しました。
ドロップダウンとの違いはどこにあるのでしょうか?
イメージ説明

・フォームクラスでアノテーションで解決できないかと調べましたが、
typemismatchを直接弾くようなアノテーションはなかったと記憶しています。

以下参考にしたサイトですが、このようなエラーは初めて対処するということもあり
情報が整理しきれない部分がありますがご教示いただけると幸いです。

参考にしたサイト
https://snowsaber.dip.jp/page/spring/validation.html
https://terasolunaorg.github.io/guideline/public_review/ArchitectureInDetail/Validation.html#jsr-303
https://qiita.com/suema0331/items/9b138e5aa2b46009694e

補足情報(FW/ツールのバージョンなど)

STS-4.10.0.RELEASE
java11

ここにより詳細な情報を記載してください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Luice

2021/07/26 06:34

obj.id(Integer) と書いてありますが、int型になっているからではないでしょうか? Integer型ならnullを許容するので、BeanValidationなどのValidationチェックで落とせると思います。 とはいえ、optionの値をユーザーに書き換えられたらtypeMismatchの発生は避けられないので、基本的にString型で受け取る事を強くおすすめします。
m.ts10806

2021/07/26 06:37

value属性つけてみては。
guest

回答1

0

自己解決

回答頂いた方にはお礼申し上げます。

そもそもhtmlのほうで特定の選択肢を選択不可にする記法を発見しましたので、
今回はそちらで対応させていただきます。ありがとうございました。

<option disabled selected value></option>

投稿2021/07/27 02:57

asahiko123

総合スコア43

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問