ModelAttribute 仅将第一个值添加到列表中
ModelAttribute adds only 1st value into List
在我看来,我生成了具有属性 multiple=multiple 的输入 "username"、select,其名称为 "rolesss".
我的问题是,如果我通过 post 发送此类表单,我的控制器应该将角色转换为列表,但我只得到包含单个元素的列表。
例如:
我发送 post,值:
username:MyUser
_csrf:aef50238-92cf-48df-86a4-cb6e2b8f62c9
rolesss:USER
rolesss:ADMIN
在我的控制器的调试模式下,我看到值:
角色:"USER"
用户名:"MyUser"
"ADMIN" 确实消失了。
我的控制器看起来像:
@Controller
@RequestMapping("/user-management")
public class UserManagementController {
@RequestMapping("")
public ModelAndView home() {
ModelAndView modelAndView = new ModelAndView();
modelAndView.setViewName("pages/user-management");
return modelAndView;
}
@RequestMapping(value = "", method = RequestMethod.POST)
public ModelAndView changeRoles(@ModelAttribute("username") String username,@ModelAttribute("rolesss") List<String> rolesss) {
return null;
}
}
我认为我将 2 个 thymeleaf 片段合并为 1 个,在我的代码中 #user-roles-form 位于单独的片段中,但我认为它不应该改变任何东西:
<th:block layout:fragment="main-content">
<section>
<h2 class="section-title no-margin-top">Role Management</h2>
<div class="form-group">
<div class="panel panel-primary">
<div class="panel-heading">Změna rolí uživatele</div>
<div class="panel-body">
<form class="form-horizontal" role="form" action="/user-management" method="post">
<div class="form-group">
<label for="user-name" class="col-sm-2 control-label">Uživatel</label>
<div class="col-sm-10">
<input id="user-name" class="autocomplete form-control" type="text"
placeholder="Jméno uživatele" name="username"/>
</div>
<input type="hidden"
th:name="${_csrf.parameterName}"
th:value="${_csrf.token}"/>
</div>
<div id="user-roles-form" th:fragment="roles(roles)" xmlns:th="http://www.thymeleaf.org">
<div class="form-group">
<label for="user-roles" class="col-sm-2 control-label">Uživatelovy role</label>
<div class="col-sm-10">
<select multiple="multiple" class="form-control" id="user-roles" name="rolesss">
<th:block th:each="role : ${roles}">
<option th:value="${role.userRole.role}" th:text="${role.userRole.role}" th:selected="${role.selected}"></option>
</th:block>
</select>
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-10">
<button type="submit" class="btn btn-ar btn-primary">Uložit</button>
</div>
</div>
</div>
</form>
</div>
</div>
</div>
</section>
</th:block>
尝试在您的控制器中使用如下所示
在您的 HTML 或 JSP
<form modelAttribute="your_model_name"></form>
如果您使用模型属性,则使用 @ModelAttribute
否则,使用@RequestParam("username")
你的情况
@RequestMapping(value = "", method = RequestMethod.POST)
public ModelAndView changeRoles(@RequestParam("username") String username,@RequestParam("rolesss") List<String> rolesss) {
..........
.........
return null;
}
在我看来,我生成了具有属性 multiple=multiple 的输入 "username"、select,其名称为 "rolesss".
我的问题是,如果我通过 post 发送此类表单,我的控制器应该将角色转换为列表,但我只得到包含单个元素的列表。
例如: 我发送 post,值:
username:MyUser
_csrf:aef50238-92cf-48df-86a4-cb6e2b8f62c9
rolesss:USER
rolesss:ADMIN
在我的控制器的调试模式下,我看到值: 角色:"USER" 用户名:"MyUser"
"ADMIN" 确实消失了。
我的控制器看起来像:
@Controller
@RequestMapping("/user-management")
public class UserManagementController {
@RequestMapping("")
public ModelAndView home() {
ModelAndView modelAndView = new ModelAndView();
modelAndView.setViewName("pages/user-management");
return modelAndView;
}
@RequestMapping(value = "", method = RequestMethod.POST)
public ModelAndView changeRoles(@ModelAttribute("username") String username,@ModelAttribute("rolesss") List<String> rolesss) {
return null;
}
}
我认为我将 2 个 thymeleaf 片段合并为 1 个,在我的代码中 #user-roles-form 位于单独的片段中,但我认为它不应该改变任何东西:
<th:block layout:fragment="main-content">
<section>
<h2 class="section-title no-margin-top">Role Management</h2>
<div class="form-group">
<div class="panel panel-primary">
<div class="panel-heading">Změna rolí uživatele</div>
<div class="panel-body">
<form class="form-horizontal" role="form" action="/user-management" method="post">
<div class="form-group">
<label for="user-name" class="col-sm-2 control-label">Uživatel</label>
<div class="col-sm-10">
<input id="user-name" class="autocomplete form-control" type="text"
placeholder="Jméno uživatele" name="username"/>
</div>
<input type="hidden"
th:name="${_csrf.parameterName}"
th:value="${_csrf.token}"/>
</div>
<div id="user-roles-form" th:fragment="roles(roles)" xmlns:th="http://www.thymeleaf.org">
<div class="form-group">
<label for="user-roles" class="col-sm-2 control-label">Uživatelovy role</label>
<div class="col-sm-10">
<select multiple="multiple" class="form-control" id="user-roles" name="rolesss">
<th:block th:each="role : ${roles}">
<option th:value="${role.userRole.role}" th:text="${role.userRole.role}" th:selected="${role.selected}"></option>
</th:block>
</select>
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-10">
<button type="submit" class="btn btn-ar btn-primary">Uložit</button>
</div>
</div>
</div>
</form>
</div>
</div>
</div>
</section>
</th:block>
尝试在您的控制器中使用如下所示
在您的 HTML 或 JSP
<form modelAttribute="your_model_name"></form>
如果您使用模型属性,则使用 @ModelAttribute
否则,使用@RequestParam("username")
你的情况
@RequestMapping(value = "", method = RequestMethod.POST)
public ModelAndView changeRoles(@RequestParam("username") String username,@RequestParam("rolesss") List<String> rolesss) {
..........
.........
return null;
}