Поле всегда равно нулю в методе Spring Boot Postmapping

Я хочу связать свою таблицу 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>

And this is my Java code, where the field isActive of UserCreationDto is always null.

@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.

введите здесь описание изображения

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

введите здесь описание изображения

Это мой метод @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 всегда имеет значение null.

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

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


person Bernd    schedule 23.12.2018    source источник
comment
как насчет того, чтобы попробовать использовать REST API с Postman, чтобы убедиться, что приложение Spring Boot работает нормально?   -  person IEE1394    schedule 24.12.2018
comment
Я уже сделал это, но при отправке моего запроса я всегда сначала получаю свою страницу входа. Я не так привык к Spring Boot и Postman, и я все еще учусь.   -  person Bernd    schedule 24.12.2018
comment
поэтому добавьте basicauth в конфигурацию безопасности spring и сначала попробуйте ее с почтальоном ... если REST API работает, вы могли бы работать с интерфейсом ... в противном случае это было бы сложно ... другой вещью могут быть инструменты разработчика вашего браузера. .. вы получаете их, нажав F12 для chrome и firefox, я думаю .. после перезагрузки страницы вы можете увидеть свой запрос, который отправляется браузером ...   -  person IEE1394    schedule 24.12.2018


Ответы (2)


Я думаю, что у вас есть много вариантов набора. Вам это не нужно :checked:

<input  th:field="*{users[__${itemStat.index}__].isActive}"
        class="checkBox"    
        type="checkBox"
        name="checkBox" />
person Simon Martinelli    schedule 23.12.2018
comment
Спасибо за вашу помощь, но у меня нет проблем с HTML-кодом. Я думаю, что моя проблема связана с моим кодом Java. При отправке формы мое поле isActive в @ModelAttribute UserCreationDto userTableSettings всегда имеет значение null. - person Bernd; 23.12.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}"
/>

Теперь единственная проблема, с которой я столкнулся, заключается в том, как обновить мой столбец логического типа в 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);

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

Может быть, кто-то может дать мне последнюю подсказку, пожалуйста!

person Bernd    schedule 24.12.2018