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 中获取,避免越权修改。

相关推荐
屋外雨大,惊蛰出没几秒前
深入浅出Spring Boot
java·spring boot·ioc·aop
流星白龙7 分钟前
【MySQL高阶】26.事务(1)
数据库·mysql
Zella折耳根20 分钟前
复习篇-继承和接口
java·开发语言·python
程序员二叉27 分钟前
【JVM】OOM详解+JVM参数+FullGC排查+CPU飙高+死锁+内存泄漏+命令大全
java·开发语言·jvm·面试
云烟成雨TD28 分钟前
Spring AI 1.x 系列【47】 MCP Annotations 模块
java·人工智能·spring
不知名的老吴1 小时前
线程的生命周期之线程同步
java·开发语言·jvm
协享科技1 小时前
Spring Boot 与 Go 双服务架构实践:从单体拆分到通信设计
java·人工智能·spring boot·后端·架构·golang·ai编程
这个DBA有点耶1 小时前
索引优化深潜(下):索引合并、ICP 与索引设计的实战法则
数据库·mysql·架构
用户3074596982071 小时前
EXPLAIN 执行计划 完全精通指南
mysql
码语智行2 小时前
地图上图、空间拓扑查询示例
java·arcgis