金刀的博客 | SpringBoot validate 服务端数据校验入门

本文介绍了SpringBoot如何使用hibernate-validator进行服务端数据校验,包括实体类添加校验规则、Controller中开启校验以及解决'Neither BindingResult nor plain target object for bean name ‘user’ available as request attribute'异常的方法。此外,还列举了一些常见的校验规则,如@NotBlank、@NotEmpty、@Length、@Min和@Max等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SpringBoot validate服务端数据校验

SpringBoot使用了hibernate-validate数据校验框架

SpringBoot表单数据校验步骤

1.在实体类中(entity/pojo)添加校验规则

public class User {
	@Length(min = 5,max = 15)	// 长度最少不能小于5位,最大不能大于15位
	@NotBlank(message = "用户名不能为空")	// 表示用户名不能为空
	private String username;	// 用户名
	
	@Length(min = 8,max = 20)	// 密码长度不能小于8位并且不能大于20位
	@NotBlank(message = "密码不能为空")	// 密码不能为空
	private String password; 	// 密码
	private String address;		// 地址
	
	@Length(min = 11,max = 11,message = "手机号格式错误")
	private String phone;		// 手机号
	
	@Min(value = 12)	// 年龄最小值为12岁
	@Max(value = 100)	// 年龄最大值为100岁
	private Integer age;
	
	@Email	// 验证邮箱是否合法
	private String email;	// 邮箱
	
	public User() {
		super();
	}
	
	public User(String username, String password, String address, String phone, Integer age, String email) {
		super();
		this.username = username;
		this.password = password;
		this.address = address;
		this.phone = phone;
		this.age = age;
		this.email = email;
	}

	public String getUsername() {
		return username;
	}
	public void setUsername(String username) {
		this.username = username;
	}
	public String getPassword() {
		return password;
	}
	public void setPassword(String password) {
		this.password = password;
	}
	public String getAddress() {
		return address;
	}
	public void setAddress(String address) {
		this.address = address;
	}
	public String getPhone() {
		return phone;
	}
	public void setPhone(String phone) {
		this.phone = phone;
	}
	
	public Integer getAge() {
		return age;
	}

	public void setAge(Integer age) {
		this.age = age;
	}

	public String getEmail() {
		return email;
	}
	public void setEmail(String email) {
		this.email = email;
	}

	@Override
	public String toString() {
		return "User [username=" + username + ", password=" + password + ", address=" + address + ", phone=" + phone
				+ ", age=" + age + ", email=" + email + "]";
	}
}

2.在Controller中开启校验

/**
 * 新增方法
 * @valid	// 开启对User对象的数据校验
 * BindingResult	// 封装了校验的结果
 * @param user
 * @return
 */
@RequestMapping(value = "/save")
public String userSave(@Valid User user, BindingResult result) {
	/**
	 * result.hasErrors该方法返回一个布尔值,
	 * 当布尔值为true时,表示校验失败
	 * 当布尔值为false时,表示校验成功
	 */
	if(result.hasErrors()) {
		// 数据校验失败,返回到请求时的页面
		return "index";
	}
	System.err.println(user);
	return "success";
}

3.在页面中获取错误信息(使用的是Thymeleaf模板引擎)

<form action="/save" method="post">
	<table align="center">
		<tr>
			<th colspan="2" align="center">Spring Boot validate</th>
		</tr>
		<tr>
			<td>用户名</td>
			<td><input type="text" name="username"></td>
			<td><font color="red" th:errors="${user.username}"></font></td>
		</tr>
		<tr>
			<td>密码</td>
			<td><input type="password" name="password"></td>
			<td><font color="red" th:errors="${user.password}"></font></td>
		</tr>
		<tr>
			<td>地址</td>
			<td><input type="text" name="address"></td>
			<td><font color="red" th:errors="${user.address}"></font></td>
		</tr>
		<tr>
			<td>手机号</td>
			<td><input type="text" name="phone"></td>
			<td><font color="red" th:errors="${user.phone}"></font></td>
		</tr>
		<tr>
			<td>年龄</td>
			<td><input type="text" name="age"></td>
			<td><font color="red" th:errors="${user.age}"></font></td>
		</tr>
		<tr>
			<td>邮箱</td>
			<td><input type="text" name="email"></td>
			<td><font color="red" th:errors="${user.email}"></font></td>
		</tr>
		<tr>
			<td colspan="2" align="center"><input type="submit" value="提交"></td>
		</tr>
	</table>
</form>
  • **“Neither BindingResult nor plain target object for bean name ‘user’ available as request attribute”**异常的解决方案

在跳转页面的方法中注入一个对象,来解决问题,要求参数对象的变量名必须是对象的类名的全称首字母小写

  • Java后端代码片段
/**
 * 解决“java.lang.IllegalStateException: Neither BindingResult nor plain target object for bean name 'user' available as request attribute”异常:
 * 	可以在跳转页面的方法中注入一个实体对象
 * 注意:
 * 	由于SpringMVC会将该对象放入到Model中传值。key的名称会使用该对象的驼峰式的命名规则来作为key。
 * 	参数的变量名需要与对象的名称相同,将首字母小写。
 *
 * @param page	请求的页面名称
 * @return
 */
@RequestMapping(value = "/{page}")
public String returnPage(@PathVariable String page,User user) {
	return page;
}

/**
 * 新增方法
 * @valid	// 开启对User对象的数据校验
 * BindingResult	// 封装了校验的结果
 * @param user
 * @return
 */
@RequestMapping(value = "/save")
public String userSave(@Valid User user, BindingResult result) {
	/**
	 * result.hasErrors该方法返回一个布尔值,
	 * 当布尔值为true时,表示校验失败
	 * 当布尔值为false时,表示校验成功
	 */
	if(result.hasErrors()) {
		// 数据校验失败,返回到请求时的页面
		return "index";
	}
	System.err.println(user);
	return "success";
}
  • html代码片段
<form action="/save" method="post">
	<table align="center">
		<tr>
			<th colspan="2" align="center">Spring Boot validate</th>
		</tr>
		<tr>
			<td>用户名</td>
			<td><input type="text" name="username"></td>
			<td><font color="red" th:errors="${user.username}"></font></td>
		</tr>
		<tr>
			<td>密码</td>
			<td><input type="password" name="password"></td>
			<td><font color="red" th:errors="${user.password}"></font></td>
		</tr>
		<tr>
			<td>地址</td>
			<td><input type="text" name="address"></td>
		</tr>
		<tr>
			<td>手机号</td>
			<td><input type="text" name="phone"></td>
		</tr>
		<tr>
			<td colspan="2" align="center"><input type="submit" value="提交"></td>
		</tr>
	</table>
</form>
  • 如果参数的名称需要做改变,则可以采用@ModelAttribute(value = “值”)注解形式实现
  • Java后端代码片段
/**
 * 
 * 如果想为传递的对象更改名称,可以使用@ModelAttribute(value = "users")这表示当前传递的对象的key为"users",
 * 那么在页面中获取该对象的key也需要修改为“users”
 * @param page	请求的页面名称
 * @return
 */
@RequestMapping(value = "/{page}")
public String returnPage(@PathVariable String page,@ModelAttribute(value = "users") User user) {
	return page;
}

/**
 * 新增方法
 * @valid	// 开启对User对象的数据校验
 * BindingResult	// 封装了校验的结果
 * @param user
 * @return
 */
@RequestMapping(value = "/save")
public String userSave(@ModelAttribute(value = "users")@Valid User user, BindingResult result) {
	/**
	 * result.hasErrors该方法返回一个布尔值,
	 * 当布尔值为true时,表示校验失败
	 * 当布尔值为false时,表示校验成功
	 */
	if(result.hasErrors()) {
		// 数据校验失败,返回到请求时的页面
		return "index";
	}
	System.err.println(user);
	return "success";
}
  • HTML代码片段
form action="/save" method="post">
	<table align="center">
		<tr>
			<th colspan="2" align="center">Spring Boot validate</th>
		</tr>
		<tr>
			<td>用户名</td>
			<td><input type="text" name="username"></td>
			<td><font color="red" th:errors="${users.username}"></font></td>
		</tr>
		<tr>
			<td>密码</td>
			<td><input type="password" name="password"></td>
			<td><font color="red" th:errors="${users.password}"></font></td>
		</tr>
		<tr>
			<td>地址</td>
			<td><input type="text" name="address"></td>
		</tr>
		<tr>
			<td>手机号</td>
			<td><input type="text" name="phone"></td>
		</tr>
		<tr>
			<td colspan="2" align="center"><input type="submit" value="提交"></td>
		</tr>
	</table>
</form>

其他校验规则

  • @NotBlank:判断字符串是否为null或者空字符串,去掉首位空格;
  • @NotEmpty:判断字符串是否为null或者空字符串;
  • @Length:判断字符的长度,例如:@Length(min = 5,max = 15) // 长度最少不能小于5位,最大不能大于15位
  • @Min:判断数值最小值,例如:@Min(value = 12) // 年龄最小值为12岁
  • @Max:判断数值最大值,例如:@Max(value = 100) // 年龄最大值为100岁
  • @Email:判断邮箱是否合法,例如:@Email // 验证邮箱是否合法
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值