Поле всегда пусто в методе Spring Boot Postmapping - PullRequest
0 голосов
/ 23 декабря 2018

Я хочу связать свою таблицу HTML со всеми полями с кодом Java в Spring Boot.Поэтому я также аннотировал свой метод с помощью Postmapping.

Мне уже удалось показать все поля в Thymeleaf, и я также смог соответственно установить значение checkBox (true / false).

Это мой HTML-код Thymeleaf:

<form action="#" th:action="@{/mitarbeiterverwaltung}" th:object="${users}" method="post">
<fieldset>
    <table border="1" align="center">
        <thead>
            <tr>
                <!-- <th:text = "#{mitarbeiterverwaltung.active}>Active ( Tick ) / Passive</th>-->
                <th>Active ( Tick ) / Passive</th>
                <th>ID</th>
                <th>Username</th>
                <th>Anzeigename</th>
                <th>Dienstnummer</th>
            </tr>
        </thead>
        <tbody>
            <tr th:each="user, itemStat : *{users}">
                <td><input  th:field="*{users[__${itemStat.index}__].isActive}"
                            th:checked="${user.isActive}"
                            class="checkBox"    
                            type="checkBox"
                            name="checkBox" 

                /></td>
                <td><input  th:field="*{users[__${itemStat.index}__].id}" 
                            readonly/></td>
                <td><input  th:field="*{users[__${itemStat.index}__].username}" 
                            readonly/></td>
                <td><input  class="anzeigename" 
                            type="text" 
                            name="anzeigename" 
                            th:field="*{users[__${itemStat.index}__].anzeigename}" 
                            th:id="${itemStat.index}" 
                            readonly/></td>
                <td><input  class="dienstnummer" 
                            type="text" 
                            name="dienstnummer" 
                            th:field="*{users[__${itemStat.index}__].dienstnummer}" 
                            th:id="${itemStat.index}" 
                            readonly/></td>
            </tr>
        </tbody>
    </table>
    <br />
    <div style="text-align:center;">
        <input type="submit" id="submitButton" th:value="Speichern"/>
    </div>
</fieldset>

А это мой код Java, где поле isActive of UserCreationDto всегда равно нулю.

@PostMapping
public String updateActivePassiveUser(@ModelAttribute UserCreationDto userTableSettings,
        @RequestParam("checkBox") String checkBoxName, BindingResult result, Model model, Errors errors) {

    logger.info("Method {} called in {}", new Object() {}.getClass().getEnclosingMethod().getName(), this.getClass().getName());

    if (errors.hasErrors()) {
        logger.error("Error in {}", new Object() {}.getClass().getEnclosingMethod().getName());
        return "error";
    }

    List<Benutzer> users = userManagementServiceImpl.getAllUsers();

    userManagementServiceImpl.updateActivePassiveUser(1, 0);

    return "redirect:/mitarbeiterverwaltung?success";
}

Вот изображение поля в коде Java, где метод помечен @ PostMapping

enter image description here

И так выглядит мой @RequestMapping:

enter image description here

Это мой метод @RequestMapping:

@RequestMapping
public String showUserManagement(Model model) {
    logger.info("Method {} called in {}", new Object() {}.getClass().getEnclosingMethod().getName(), this.getClass().getName());
    List<Benutzer> users = userManagementServiceImpl.getAllUsers();
    userForm = userManagementServiceImpl.saveUserForm(users);
    model.addAttribute("users", userForm);
    return "mitarbeiterverwaltung";
}

My UserCreationDto, где все поля добавляются в список:

public class UserCreationDto {

private List<User> users = new ArrayList<>();

public void addUser(User user) {
    this.users.add(user);
}

public List<User> getUsers() {
    return users;
}

public void setUsers(List<User> users) {
    this.users = users;
}
}

И мой простой класс POJO со всеми полями

@Data

   public class User {
    //@SafeHtml prevents XSS ( Cross-Site Scripting )
    @SafeHtml
    private String username;
    private String password;
    private String anzeigename;
    private String dienstnummer;
    private long id;
    private Boolean isActive;
}

Другие поля, такие как anzeigename, dienstnummer, id и username, заполнены в моем Java-коде, однако isactive всегда равен нулю.

Может быть, кто-нибудь подскажет, что я здесь не так делаю.

Заранее большое спасибо.

Ответы [ 2 ]

0 голосов
/ 24 декабря 2018

Я нашел другой способ сейчас, но он не очень хорош.

@PostMapping
public String updateActivePassiveUser(@Valid @ModelAttribute("userForm") UserCreationDto userTableSettings,
        @RequestParam List<String> searchValues, BindingResult result, Model model, Errors errors) {

Поле searchValues ​​содержит все отмеченные флажки.Это мое мнение:

<td><input  type="checkbox"
    name="searchValues"
    th:value="${user.id}"
    th:checked="${user.isActive}"
/>

Теперь единственная проблема, с которой я сталкиваюсь - это как обновить мой столбец типа Boolean в Postgresql?

Для выполнения этой задачи я вызываю это:

userRepo.updateActivePassiveUser(new Boolean("False"), id);

@Modifying
@Query(value = "UPDATE benutzer SET active = :active WHERE id = :id", nativeQuery = true)
@Transactional
void updateActivePassiveUser(@Param("active") Boolean active, @Param("id") long id);

Однако значение в моей базе данных никогда не меняется.

Возможно, кто-то может дать мне последний совет, пожалуйста!

0 голосов
/ 23 декабря 2018

Я думаю, вам нужно установить множество параметров.Вам не нужно th: проверено:

<input  th:field="*{users[__${itemStat.index}__].isActive}"
        class="checkBox"    
        type="checkBox"
        name="checkBox" />
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...