由于用戶的登錄涉及到了身份這一方面的認證,所以我們就可以通過
JWT
進行用戶的鑒權(quán),以確認用戶的身份。
authed.PUT("user", api.UserUpdate)
//用戶修改信息的服務(wù)
type UserUpdateService struct {
NickName string `form:"nickname" json:"nickname" binding:"required,min=5,max=10"`
UserName string `form:"user_name" json:"user_name" binding:"required,min=5,max=15"`
}
func (service UserUpdateService) Update(id uint) serializer.Response {...}
var userUpdateService service.UserUpdateService
Authorization
的值claims,_ := util.ParseToken(c.GetHeader("Authorization"))
c.ShouldBind(&userUpdateService)
update
方法res := userUpdateService.Update(claims.ID)
c.JSON(200, res)
func UserUpdate(c *gin.Context) {
var userUpdateService service.UserUpdateService
claims,_ := util.ParseToken(c.GetHeader("Authorization"))
if err := c.ShouldBind(&userUpdateService); err == nil {
res := userUpdateService.Update(claims.ID)
c.JSON(200, res)
} else {
c.JSON(200, ErrorResponse(err))
logging.Info(err)
}
}
Authorization
解析出來的id找到該用戶var user model.User
code := e.SUCCESS
//找到用戶
err := model.DB.First(&user, id).Error
if err != nil {
logging.Info(err)
code = e.ErrorDatabase
return serializer.Response{
Status: code,
Msg: e.GetMsg(code),
Error: err.Error(),
}
}
user.Nickname = service.NickName
user.UserName = service.UserName
err = model.DB.Save(&user).Error
return serializer.Response{
Status: code,
Data: serializer.BuildUser(user),
Msg: e.GetMsg(code),
}
func (service UserUpdateService) Update(id uint) serializer.Response {
var user model.User
code := e.SUCCESS
//找到用戶
err := model.DB.First(&user, id).Error
if err != nil {
logging.Info(err)
code = e.ErrorDatabase
return serializer.Response{
Status: code,
Msg: e.GetMsg(code),
Error: err.Error(),
}
}
user.Nickname = service.NickName
user.UserName = service.UserName
err = model.DB.Save(&user).Error
if err != nil {
logging.Info(err)
code = e.ErrorDatabase
return serializer.Response{
Status: code,
Msg: e.GetMsg(code),
Error: err.Error(),
}
}
return serializer.Response{
Status: code,
Data: serializer.BuildUser(user),
Msg: e.GetMsg(code),
}
}