spring boot 9

一、实体参数校验(Spring Validation)

1. 核心注解说明

表格

注解 作用 适用场景
@NotNull 值不能为 null 数值类型(如 Integer id
@NotEmpty 不为 null 且内容不为空 字符串类型(如昵称、邮箱)
@Pattern 正则表达式校验格式 用户名 / 昵称长度、格式限制
@Email 校验邮箱格式 邮箱字段

2. 实体类(User.java)改造

java

运行

复制代码
@Data
public class User {
    @NotNull(message = "用户ID不能为空")
    private Integer id; // 主键ID

    @Pattern(regexp = "^\\w{5,16}$", message = "用户名必须是5-16位字母/数字/下划线")
    private String username; // 用户名(非必填)

    @NotEmpty(message = "昵称不能为空")
    @Pattern(regexp = "^\\S{1,10}$", message = "昵称必须是1-10位非空字符")
    private String nickname; // 昵称

    @NotEmpty(message = "邮箱不能为空")
    @Email(message = "邮箱格式不正确")
    private String email; // 邮箱

    private String userPic; // 用户头像地址
    private LocalDateTime createTime; // 创建时间
    private LocalDateTime updateTime; // 更新时间
}

3. Controller 接口开启校验

java

运行

复制代码
@PutMapping("/update")
public Result update(@RequestBody @Validated User user) {
    userService.update(user);
    return Result.success();
}
  • @Validated:开启实体类参数校验,校验失败会自动抛出异常

二、用户信息更新接口实现

1. 更新用户基本信息(/update

Controller 层

java

运行

复制代码
@PutMapping("/update")
public Result update(@RequestBody @Validated User user) {
    userService.update(user);
    return Result.success();
}
Service 层

java

运行

复制代码
public void update(User user) {
    // 设置更新时间
    user.setUpdateTime(LocalDateTime.now());
    userMapper.update(user);
}
Mapper 层(SQL)

xml

复制代码
<update id="update">
    update user
    set nickname = #{nickname},
        email = #{email},
        update_time = #{updateTime}
    where id = #{id}
</update>

2. 更新用户头像(/updateAvatar

Controller 层

java

运行

复制代码
@PatchMapping("/updateAvatar")
public Result updateAvatar(@RequestParam String avatarUrl) {
    // 从 ThreadLocal 获取当前用户ID
    Map<String, Object> claims = ThreadLocalUtil.get();
    Integer userId = (Integer) claims.get("id");
    
    userService.updateAvatar(userId, avatarUrl);
    return Result.success();
}
Service 层

java

运行

复制代码
public void updateAvatar(Integer userId, String avatarUrl) {
    userMapper.updateAvatar(userId, avatarUrl, LocalDateTime.now());
}
Mapper 层(SQL)

xml

复制代码
<update id="updateAvatar">
    update user
    set user_pic = #{avatarUrl},
        update_time = #{updateTime}
    where id = #{userId}
</update>

三、关键注意事项

  1. 参数校验生效条件

    • 实体类字段添加校验注解
    • Controller 接口参数前添加 @Validated
    • 已引入 spring-boot-starter-validation 依赖
  2. 全局异常处理 校验失败会抛出 MethodArgumentNotValidException,需要在全局异常处理器中处理:

    java

    运行

    复制代码
    @ExceptionHandler(MethodArgumentNotValidException.class)
    public Result handleValidationException(MethodArgumentNotValidException e) {
        String message = e.getBindingResult().getFieldError().getDefaultMessage();
        return Result.error(message);
    }
  3. 用户 ID 的安全获取 头像更新接口中,用户 ID 不要由前端传入,应从 ThreadLocal 中获取,避免越权修改。

相关推荐
执明wa1 小时前
从 T 到协变逆变
java·开发语言·数据结构
XiYang-DING1 小时前
【Java EE】 TCP—异常情况处理
java·tcp/ip·java-ee
lianghyan2 小时前
List.stream().min
java·开发语言
老码观察2 小时前
MySQL 慢 SQL 治理实战:从索引原理到真实踩坑
sql·mysql
思麟呀2 小时前
MySQL的视图特性和用户权限管理
数据库·mysql
guaiyud52 小时前
MySQL 8.0 小白安装教程(Windows + macOS 双版本)
mysql·安装·小白
爱笑的源码基地2 小时前
小微企业ERP源码,采用SpringBoot+Vue+ElementUI+UniAPP技术架构,支持二次开发及商用授权
java·源码·二次开发·erp·源代码·mrp生产计划
happymaker06262 小时前
Spring学习日记——DAY03(yml文件)
java·spring boot·spring
凯瑟琳.奥古斯特2 小时前
操作系统核心结构解析
java·开发语言·c++·python·职场和发展