这是我参与11月更文挑战的第26天,活动详情查看:2021最后一次更文挑战
写在前面
由于用户的登录涉及到了身份这一方面的认证,所以我们就可以通过
JWT
进行用户的鉴权,以确认用户的身份。
- 编写用户更新的请求路由
1 | go复制代码authed.PUT("user", api.UserUpdate) |
2.1 service层
- 定义一个用户修改的结构体
只能修改用户名或是昵称,修改密码后续再说。
1 | go复制代码//用户修改信息的服务 |
- 定义用户信息修改函数
1 | go复制代码func (service UserUpdateService) Update(id uint) serializer.Response {...} |
2.2 api层
- 定义一个用户更新服务
1 | go复制代码var userUpdateService service.UserUpdateService |
- 读取请求头中
Authorization
的值
1 | go复制代码claims,_ := util.ParseToken(c.GetHeader("Authorization")) |
- 绑定这个服务
1 | go复制代码c.ShouldBind(&userUpdateService) |
- 调用这个服务的
update
方法
1 | go复制代码res := userUpdateService.Update(claims.ID) |
- 上下文返回
1 | go复制代码c.JSON(200, res) |
- api层完整代码
1 | go复制代码func UserUpdate(c *gin.Context) { |
- 根据
Authorization
解析出来的id找到该用户
1 | go复制代码 var user model.User |
- 根据传送来的信息对用户的原本信息进行修改
1 | go复制代码 user.Nickname = service.NickName |
- 保存到数据库中
1 | go复制代码err = model.DB.Save(&user).Error |
- 返回用户的信息
1 | go复制代码 return serializer.Response{ |
- 服务层完整代码
1 | go复制代码func (service UserUpdateService) Update(id uint) serializer.Response { |
本文转载自: 掘金