SpringBoot学习-Day02-黑马大事件学习-更新用户信息

文章详细介绍了如何使用SpringMVC构建RESTfulAPI,包括更新用户基本信息(昵称、邮箱)、头像以及修改密码的控制器、服务层、Mapper和DAO实现。涉及了参数验证、数据库操作和数据映射。
摘要由CSDN通过智能技术生成

更新用户基本信息

接口基本信息

请求路径:/user/update

请求方式:PUT

接口描述:该接口用于更新已登录用户的基本信息(除头像和密码)

请求参数

参数名称说明类型是否必须备注
id主键IDnumber
username用户名string5~16位非空字符
nickname昵称string1~10位非空字符
email邮箱string满足邮箱的格式

响应数据

名称类型是否必须默认值备注其他信息
codenumber必须响应码, 0-成功,1-失败
messagestring非必须提示信息
dataobject非必须返回的数据

响应数据样例:

{
    "code": 0,
    "message": "操作成功",
    "data": null
}

代码编写

controller层

   //更新用户基本信息
    @PutMapping("/update")
    public Result update(@RequestBody @Validated User user){
        userService.update(user);
        return Result.success();
    }

service层

UserService
   //更新
    void update(User user);

UserServiceImpl	
    @Override
    public void update(User user) {
        user.setUpdateTime(LocalDateTime.now());
        userMapper.update(user);
    }

Mapper层

 @Update("update user set nickname=#{nickname},email=#{email},update_time=#{updateTime} where id=#{id}")
    void update(User user);

dao层

@Data
public class User {
    @NotNull
    private Integer id;//主键ID
    private String username;//用户名
    @JsonIgnore  //让springMVC把当前对象转换成json字符串的时候,忽略password,最终的json字符串中就没有password这个属性了
    private String password;//密码
    @NotEmpty
    @Pattern(regexp = "^\\S{1,10}$")
    private String nickname;//昵称
    private String email;//邮箱
    private String userPic;//用户头像地址
    private LocalDateTime createTime;//创建时间
    private LocalDateTime updateTime;//更新时间
}

更新用户头像

接口基本信息

请求路径:/user/updateAvatar

请求方式:PATCH

接口描述:该接口用于更新已登录用户的头像

响应参数

参数名称说明类型是否必须备注
avatarUrl头像地址stringurl地址

代码

controller层

 //更新用户头像
    @PatchMapping("/updateAvatar")
    public Result updateAvater(@RequestParam String avatarUrl){
        userService.updateAvater(avatarUrl);
        return Result.success();
    }

Mapper层

    @Update("update user set user_pic=#{avaterUrl},update_time=now() where id = #{id}")
    void updateAvater(String avaterUrl,Integer id);

但是此时传递的头像地址可能是不正确的,所以我们要进行校验
步骤:在controller中updateAvater方法参数前加上@URL

   //更新用户头像
    @PatchMapping("/updateAvatar")
    public Result updateAvater(@RequestParam @URL String avatarUrl){
        userService.updateAvater(avatarUrl);
        return Result.success();
    }

更新用户密码

接口基本信息

请求路径:/user/updatePwd

请求方式:PATCH

接口描述:该接口用于更新已登录用户的密码

请求参数

参数名称说明类型是否必须备注
old_pwd原密码string
new_pwd新密码string
re_pwd确认新密码string

代码

controller层

    //更新用户名密码
    @PatchMapping("/updatePwd")
    public Result updatePwd(@RequestBody Map<String,String> params){
        //1.参数校验
        String oldPwd = params.get("old_pwd");
        String newPwd = params.get("new_pwd");
        String rePwd = params.get("re_pwd");

        if(!StringUtils.hasLength(oldPwd) || !StringUtils.hasLength(newPwd) || !StringUtils.hasLength(rePwd)){
            return Result.error("缺少必要的参数");
        }

        //校验原密码是否正确,1.根据用户名拿到原密码,然后再和old_pwd比对
        Map<String,Object> map = ThreadLocalUtil.get();
        String username = (String) map.get("username");
        User loginUser = userService.findByUserName(username);
        if(!loginUser.getPassword().equals(Md5Util.getMD5String(oldPwd))){
            return Result.error("原密码不正确");
        }

        //newPwd和repwd是否一样
        if(!newPwd.equals(rePwd)){
            return Result.error("你的两次填写密码不一样");
        }
        //2.调用service完成密码更新
        userService.updatePwd(newPwd);
        return Result.success();

    }

Serviceimpl

    @Override
    public void updatePwd(String newPwd) {
        Map<String,Object> map = ThreadLocalUtil.get();
        Integer id = (Integer) map.get("id");
        userMapper.updatePwd(Md5Util.getMD5String(newPwd),id);
    }

Mapper层

    @Update("update user set password=#{md5String},update_time=now() where id = #{id}")
    void updatePwd(String md5String, Integer id);
  • 10
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值