强烈推荐
分享一个大神的人工智能教程。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到人工智能的队伍中来!http://www.captainbed.net
springboot+thymeleaf报错:java.lang.IllegalStateException: Neither BindingResult nor plain target object for bean name ‘user’ available as request attribute
第一次使用thymeleaf模板引擎,遇到了很多坑,真的是烦恼了很久。
创建了一个很简单的form表单都报错了,而且找不到原因。
Controller层
@Controller
@RequestMapping("/user")
public class UserController {
@Autowired
private UserService userService;
@GetMapping(value = "/reg")
public String userRegister(Model model){
return "/userAdd";
}
@PostMapping(value = "/add", produces = {"application/json;charset=UTF-8"})
public String addUser(@ModelAttribute(value = "user") User user, Model model){
int count = userService.addUser(user);
if (count > 0){
model.addAttribute("result",new ReturnResult<User>(true, user));
return "/userList";
}else{
model.addAttribute("result",new ReturnResult<User>(false, "失败,请检查信息填写是否全面"));
return "/userAdd";
}
}
thymeleaf模板代码:
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<title>User Add</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
</head>
<body>
<div style="text-align: center;margin:0 auto;width: 1000px; ">
<h1>用户添加</h1>
<!--<form action="/user/add" method="post">
用户名:<input type="text" name="userName"/>
账号名:<input type="text" name="phone"/>
密码:<input type="password" name="password"/>
<input type="submit" value="提交"/>
</form>-->
<form action="#" th:action="@{/user/add}" th:object="${user}" method="post">
<input type="text" th:field="*{userName}"/>
<input type="text" th:field="*{phone}"/>
<input type="password" th:field="*{password}"/>
<input type="submit" value="提交"/>
</form>
</div>
</body>
</html>
报错的原因是因为html页面中的${user}并没有定义,不像jsp页面中直接对象的属性对应就可以了,这里是当你从控制器进入这个页面的时候就需要把这个对象模型传到前台。
将Controller层的方法改一下就可以了:
@GetMapping(value = "/reg")
public String userRegister(Model model){
User user = new User();
model.addAttribute("user",user);
return "/userAdd";
}
也就是传一个空的对象过去就可以了,这样就搞定了。