跳到主要内容

12、Spring Boot - 中服务端数据校验-5900字匠心出品

1.Spring Boot 对实体对象的校验

1.搭建项目环境

1.创建项目

 

2.创建实体

public class Users {
   
     
    private Integer userid;
    private String username;
    private String usersex;

    public Integer getUserid() {
   
     
        return userid;
    }

    public void setUserid(Integer userid) {
   
     
        this.userid = userid;
    }

    public String getUsername() {
   
     
        return username;
    }

    public void setUsername(String username) {
   
     
        this.username = username;
    }

    public String getUsersex() {
   
     
        return usersex;
    }

    public void setUsersex(String usersex) {
   
     
        this.usersex = usersex;
    }

    @Override
    public String toString() {
   
     
        return "Users{" +
                "userid=" + userid +
                ", username='" + username + '\'' +
                ", usersex='" + usersex + '\'' +
                '}';
    }
}

3.创建 Controller

@Controller 
@RequestMapping("/user") 
public class UsersController {
   
      
//添加用户 
@RequestMapping("/addUser") 
	public String addUser(Users users){
   
      
		System.out.println(users); 
		return "ok"; 
	} 
}

4.创建页面

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html xmlns:th="http://www.thymeleaf.org">
<link rel="shortcut icon" href="../resources/favicon.ico" th:href="@{/static/favicon.ico}"/>
<head>
    <title>地球村公民首页</title>
</head>
<body>

<form th:action="@{/user/addUser}" method="post">
    <input type="text" name="username"><br/>
    <input type="text" name="usersex"><br/>
    <input type="submit" value="OK"/>
</form>
</body>
</html>

2.对实体对象做数据校验

1.Spring Boot 数据校验的技术特点

  • Spring Boot 中使用了 Hibernate-validator 校验框架

2.对实体对象数据校验步骤

1.修改实体类添加校验规则
/**
 * @NotNull: 对基本数据类型的对象类型做非空校验
 * @NotBlank:对字符串类型做非空校验
 * @NotEmpty:对集合类型做非空校验
 */
public class Users {
   
     
    @NotNull
    private Integer userid;
    @NotBlank
    private String username;
    @NotBlank
    private String usersex;

    public Integer getUserid() {
   
     
        return userid;
    }

    public void setUserid(Integer userid) {
   
     
        this.userid = userid;
    }

    public String getUsername() {
   
     
        return username;
    }

    public void setUsername(String username) {
   
     
        this.username = username;
    }

    public String getUsersex() {
   
     
        return usersex;
    }

    public void setUsersex(String usersex) {
   
     
        this.usersex = usersex;
    }

    @Override
    public String toString() {
   
     
        return "Users{" +
                "userid=" + userid +
                ", username='" + username + '\'' +
                ", usersex='" + usersex + '\'' +
                '}';
    }
}

2.在 Controller 中开启校验
@RequestMapping("/addUser")
    public String addUser(@Validated Users users,BindingResult result){
   
     
        if(result.hasErrors()){
   
     
            return "addUser";
        }
        System.out.println(users);
        return "ok";
    }

3.在页面中获取提示信息
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html xmlns:th="http://www.thymeleaf.org">
<link rel="shortcut icon" href="../resources/favicon.ico" th:href="@{/static/favicon.ico}"/>
<head>
    <title>地球村公民首页</title>
</head>
<body>

<form th:action="@{/user/addUser}" method="post">
    <input type="text" name="username"><font color="red"><span th:errors="${users.username}"/></font><br/>
    <input type="text" name="usersex"><font color="red"><span th:errors="${users.usersex}"/></font><br/>
    <input type="submit" value="OK"/>
</form>
</body>
</html>

3.自定义错误提示信息

1.在注解中定义提示信息
@NotNull(message = "用户 ID 不能为空") 
private Integer userid; 
@NotBlank(message = "用户姓名不能为空") 
private String username; 
@NotBlank(message = "用户性别不能为空") 
private String usersex;

2.在配置文件中定义提示信息
  • 配置文件名必须是 ValidationMessages.properties
userid.notnull=\u7528\u6237Id\u4e0d\u80fd\u4e3a\u7a7a-pro 
username.notnull=\u7528\u6237\u59d3\u540d\u4e0d\u80fd\u4e3a\u7a7a-pro
usersex.notnull=\u7528\u6237\u6027\u522b\u4e0d\u80fd\u4e3a\u7a7a-pro
  

4.解决页面跳转异常

  • 在跳转页面的方法中注入一个对象,要求参数对象的变量名必须是对象类型名称首字母小写格式。
@Controller
public class PageController {
   
     
    /**
     * 跳转页面方法
     * 解决异常的方式:可以在跳转页面的方法中注入一个Users对象
     * 由于SprignMVC会将该对象放入到Model中传递,key的名称会使用该对象
     * 的驼峰命名规则来作为key
     */
    @RequestMapping("/{page}")
    public String showPage(@PathVariable String page, Users users){
   
     
        return page;
    }
}

5.修改参数 key 的名称

@Controller
public class PageController {
   
     

    /**
     * 跳转页面方法
     * 解决异常的方式:可以在跳转页面的方法中注入一个Users对象
     * 由于SprignMVC会将该对象放入到Model中传递,key的名称会使用该对象
     * 的驼峰命名规则来作为key
     */
    @RequestMapping("/{page}")
    public String showPage(@PathVariable String page, @ModelAttribute("aa") Users suibian) {
   
     
        return page;
    }
}

    /**
     * 添加用户
     */
    @RequestMapping("/addUser")
    public String addUser(@ModelAttribute("aa") @Validated Users users, BindingResult result) {
   
     
        if (result.hasErrors()) {
   
     
            List<ObjectError> list = result.getAllErrors();
            for (ObjectError err : list) {
   
     
                FieldError fieldError = (FieldError) err;
                String fieldName = fieldError.getField();
                String msg = fieldError.getDefaultMessage();
                System.out.println(fieldName + "\t" + msg);
            }
            return "addUser";
        }
        System.out.println(users);
        return "ok";
    }

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html xmlns:th="http://www.thymeleaf.org">
<link rel="shortcut icon" href="../resources/favicon.ico" th:href="@{/static/favicon.ico}"/>
<head>
    <title>地球村公民首页</title>
</head>
<body>

<form th:action="@{/user/addUser}" method="post">
    <input type="text" name="username"><font color="red"><span th:errors="${aa.username}"/></font><br/>
    <input type="text" name="usersex"><font color="red"><span th:errors="${aa.usersex}"/></font><br/>
    <input type="submit" value="OK"/>
</form>
</body>
</html>

6.其他校验规则

  • @NotNull: 判断基本数据类型的对象类型是否为 null
  • @NotBlank: 判断字符串是否为 null 或者是空串(去掉首尾空格)。
  • @NotEmpty: 判断集合是否为空。
  • @Length: 判断字符的长度(最大或者最小)
  • @Min: 判断数值最小值
  • @Max: 判断数值最大值
  • @Email: 判断邮箱是否合法

2.Spring Boot 对 Controller 中其他参数的校验

1.对参数指定校验规则

@PostMapping("/findUser") 
public String findUser(@NotBlank(message = "用户名不能为空") String username){
   
     
	System.out.println(username); 
	return "ok"; 
}

2.在 Controller 中开启校验

@Controller 
@RequestMapping("/user") 
@Validated 
public class UsersController {
   
     

3.通过全局异常处理来跳转页面

@Configuration
public class GlobalException implements HandlerExceptionResolver {
   
     
    @Override
    public ModelAndView resolveException(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object handler, Exception e) {
   
     
        ModelAndView mv = new ModelAndView();
        //判断不同异常类型,做不同视图的跳转
        if (e instanceof NullPointerException) {
   
     
            mv.setViewName("error5");
        }
        if (e instanceof ArithmeticException) {
   
     
            mv.setViewName("error6");
        }
        if (e instanceof ConstraintViolationException) {
   
     
            mv.setViewName("findUser");
        }
        mv.addObject("error", e.getMessage().split(":")[1]);
        return mv;
    }
}