--Validierungseinstellungen kommentieren Variablen der Entitätsklasse
Player.java
src/main/java/com/example/baseball/domain/Player.java
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@NotEmpty // ①
private String name;
@NotNull // ②
@Min(value = 0) // ③
@Max(value = 150)
private Integer age;
@Size(max = 20) // ④
private String team;
private String position;
-①: Wenn @ NotEmpty
hinzugefügt wird, sind null und leere Zeichen nicht zulässig.
-②: Wenn @ NotNull
hinzugefügt wird, ist null nicht zulässig.
--③: Stellen Sie den Minimalwert mit @ Min
und den Maximalwert mit @ Max
ein
-④: Fügen Sie "@ Size" hinzu, um die Anzahl der Zeichen zu begrenzen
PlayerController.java
src/main/java/com/example/baseball/controller/PlayerController.java
@GetMapping("new")
public String newPlayer(Model model) {
// ①
Player player = new Player();
model.addAttribute("player", player);
return "players/new";
}
@PostMapping
public String create(@Valid @ModelAttribute Player player, BindingResult bindingResult) { // ②
if(bindingResult.hasErrors()) return "players/new"; // ③
playerService.save(player);
return "redirect:/players";
}
@PutMapping("{id}")
public String update(@PathVariable Long id, @Valid @ModelAttribute Player player, BindingResult bindingResult) {
if(bindingResult.hasErrors()) return "players/edit";
player.setId(id);
playerService.save(player);
return "redirect:/players";
}
-①: Übergeben Sie die Player-Instanz an den neuen Erstellungsbildschirm
@Valid @ModelAttribute Player player
//↑ und ↓ sind gleich
@Valid
@ModelAttribute
Player player
-②: Wenn ein Fehler vorliegt, werden die Fehlerinformationen in "BindingResult bindingResult" festgelegt.
--③: Wenn ein Fehler auftritt, gibt bindingResult.hasErrors ()
true zurück. In diesem Fall wird der ursprüngliche Bildschirm wiederhergestellt.
new.html
src/main/resources/templates/players/new.html
<!-- ① -->
<form th:action="@{/players}" th:method="post" th:object="${player}">
<!-- ② -->
<div class="form-group" th:classappend="${#fields.hasErrors('name')}? has-error">
<label class="control-label">Name</label>
<input class="form-control" type="text" th:field="*{name}" />
<!-- ③ -->
<span class="text-danger" th:if="${#fields.hasErrors('name')}" th:errors="*{name}"></span>
</div>
<div class="form-group" th:classappend="${#fields.hasErrors('age')}? has-error">
<label class="control-label">Alter</label>
<input class="form-control" type="number" th:field="*{age}" />
<span class="text-danger" th:if="${#fields.hasErrors('age')}" th:errors="*{age}"></span>
</div>
<div class="form-group" th:classappend="${#fields.hasErrors('team')}? has-error">
<label class="control-label">Teamname</label>
<input class="form-control" type="text" th:field="*{team}" />
<span class="text-danger" th:if="${#fields.hasErrors('team')}" th:errors="*{team}"></span>
</div>
<div class="form-group" th:classappend="${#fields.hasErrors('position')}? has-error">
<label class="control-label">Verteidigungsposition</label>
<input class="form-control" type="text" th:field="*{position}" />
<span class="text-danger" th:if="${#fields.hasErrors('position')}" th:errors="*{position}"></span>
</div>
<button class="btn btn-default" type="submit">Erstellen</button>
</form>
--①: Da der Player jetzt vom Controller empfangen wird, setzen Sie ihn auf th: object.
th: class append =" $ {# fields.hasErrors ('name')}? Has-error "
hat has im Klassenattribut, wenn # fields.hasErrors ('name')
wahr ist. - Fehler hinzufügenth: Errors = "* {name}"
zeigt alle für* {name}
eingestellten Fehlermeldungen anedit.html
src/main/resources/templates/players/edit.html
<form th:action="@{/players/{id}(id=*{id})}" th:method="put" th:object="${player}">
<div class="form-group" th:classappend="${#fields.hasErrors('name')}? has-error">
<label class="control-label">Name</label>
<input class="form-control" type="text" th:field="*{name}" />
<span class="text-danger" th:if="${#fields.hasErrors('name')}" th:errors="*{name}"></span>
</div>
<div class="form-group" th:classappend="${#fields.hasErrors('age')}? has-error">
<label class="control-label">Alter</label>
<input class="form-control" type="number" th:field="*{age}" />
<span class="text-danger" th:if="${#fields.hasErrors('age')}" th:errors="*{age}"></span>
</div>
<div class="form-group" th:classappend="${#fields.hasErrors('team')}? has-error">
<label class="control-label">Teamname</label>
<input class="form-control" type="text" th:field="*{team}" />
<span class="text-danger" th:if="${#fields.hasErrors('team')}" th:errors="*{team}"></span>
</div>
<div class="form-group" th:classappend="${#fields.hasErrors('position')}? has-error">
<label class="control-label">Verteidigungsposition</label>
<input class="form-control" type="text" th:field="*{position}" />
<span class="text-danger" th:if="${#fields.hasErrors('position')}" th:errors="*{position}"></span>
</div>
<button class="btn btn-default" type="submit">aktualisieren</button>
</form>
--Nächster ist hier
Recommended Posts