七. 实现用户修改个人信息

2022-12-27 15:57:23 浏览数 (1)

前言

上一章已经实现请求体拦截,本期将会结合前一章进行功能实现

分析

  1. REST风格请求
  2. 限制修改内容

代码实现

数据持久层(dao)

在userdao接口中新增暴露出修改用户信息接口

代码语言:javascript复制
public Boolean put_userinfo(User user);

userDaoImpl中实现修改用户信息请求接口

代码语言:javascript复制
    public Boolean put_userinfo(User user){
        userExample.createCriteria().andOpenidEqualTo(user.getOpenid());
        user.setUploadNum(null);
        user.setCreateRoom(null);
//      ... where openid = openid set user = user ....
        return userMapper.updateByExampleSelective(user,userExample) == 1?true:false;
    }

服务层(service)

UserService中新增暴露出如下接口

代码语言:javascript复制
public BaseResponse put_userinfo(User user, HttpServletRequest request);

UserServiceimpl实现接口

代码语言:javascript复制
    @Transactional
    public BaseResponse put_userinfo(User user, HttpServletRequest request){
//        查询token查询是谁的请求最后再给他修改信息
        user.setOpenid(TokenUtils.tookenList(request.getHeader("token")).get(0).getOpenid());
        Assert.isTrue(userDao.put_userinfo(user),"信息修改失败");
        return RespGenerator.success_noData("用户信息修改成功");
    }

控制器层(controller)

UserController中新增Put接口

代码语言:javascript复制
    //    用户修改个人信息
    @PutMapping("/user")
    public BaseResponse user(@RequestBody User user, HttpServletRequest request){
        return userService.put_userinfo(user,request);
    }

请求流程总结

程序根据请求头的token解析出用户主键,最后根据用户主键修改数据库内容。并做修改限制。

0 人点赞