fix:修改用户信息密码不用必传

This commit is contained in:
xiangheng
2023-11-29 11:38:31 +08:00
parent 1ae107ab83
commit d1ababfe51
3 changed files with 77 additions and 10 deletions

View File

@@ -47,8 +47,8 @@ type SystemAuthAdminEditReq struct {
type SystemAuthAdminUpdateReq struct { type SystemAuthAdminUpdateReq struct {
Nickname string `form:"nickname" binding:"required,min=2,max=30"` // 昵称 Nickname string `form:"nickname" binding:"required,min=2,max=30"` // 昵称
Avatar string `form:"avatar"` // 头像 Avatar string `form:"avatar"` // 头像
Password string `form:"password" binding:"required"` // 密码 Password string `form:"password" binding:""` // 密码
CurrPassword string `form:"currPassword" binding:"required,min=6,max=32"` // 密码 CurrPassword string `form:"currPassword" binding:""` // 密码
} }
//SystemAuthAdminDelReq 管理员删除参数 //SystemAuthAdminDelReq 管理员删除参数

View File

@@ -308,7 +308,7 @@ func (adminSrv systemAuthAdminService) Update(c *gin.Context, updateReq SystemAu
avatar = updateReq.Avatar avatar = updateReq.Avatar
} }
adminMap["Avatar"] = util.UrlUtil.ToRelativeUrl(avatar) adminMap["Avatar"] = util.UrlUtil.ToRelativeUrl(avatar)
delete(adminMap, "aaa") // delete(adminMap, "aaa")
if updateReq.Password != "" { if updateReq.Password != "" {
currPass := util.ToolsUtil.MakeMd5(updateReq.CurrPassword + admin.Salt) currPass := util.ToolsUtil.MakeMd5(updateReq.CurrPassword + admin.Salt)
if currPass != admin.Password { if currPass != admin.Password {

View File

@@ -2,14 +2,56 @@ package util
import ( import (
"encoding/json" "encoding/json"
"fmt"
"io" "io"
"mime/multipart" "mime/multipart"
"x_admin/core/response" "x_admin/core/response"
"github.com/gin-gonic/gin" "github.com/gin-gonic/gin"
"github.com/gin-gonic/gin/binding" "github.com/gin-gonic/gin/binding"
"github.com/go-playground/locales/en"
"github.com/go-playground/locales/zh"
ut "github.com/go-playground/universal-translator"
"github.com/go-playground/validator/v10"
enTranslations "github.com/go-playground/validator/v10/translations/en"
chTranslations "github.com/go-playground/validator/v10/translations/zh"
) )
var trans ut.Translator
// loca 通常取决于 http 请求头的 'Accept-Language'
func transInit(local string) (err error) {
if v, ok := binding.Validator.Engine().(*validator.Validate); ok {
zhT := zh.New() //chinese
enT := en.New() //english
uni := ut.New(enT, zhT, enT)
var o bool
trans, o = uni.GetTranslator(local)
if !o {
return fmt.Errorf("uni.GetTranslator(%s) failed", local)
}
//register translate
// 注册翻译器
switch local {
case "en":
err = enTranslations.RegisterDefaultTranslations(v, trans)
case "zh":
err = chTranslations.RegisterDefaultTranslations(v, trans)
default:
err = enTranslations.RegisterDefaultTranslations(v, trans)
}
return
}
return
}
func init() {
if err := transInit("zh"); err != nil {
fmt.Printf("init trans failed, err:%v\n", err)
return
}
}
var VerifyUtil = verifyUtil{} var VerifyUtil = verifyUtil{}
// verifyUtil 参数验证工具类 // verifyUtil 参数验证工具类
@@ -17,9 +59,14 @@ type verifyUtil struct{}
func (vu verifyUtil) VerifyJSON(c *gin.Context, obj any) (e error) { func (vu verifyUtil) VerifyJSON(c *gin.Context, obj any) (e error) {
if err := c.ShouldBindBodyWith(obj, binding.JSON); err != nil { if err := c.ShouldBindBodyWith(obj, binding.JSON); err != nil {
errs, ok := err.(validator.ValidationErrors)
if !ok {
e = response.ParamsValidError.MakeData(err.Error()) e = response.ParamsValidError.MakeData(err.Error())
return return
} }
e = response.ParamsValidError.MakeData(errs.Translate(trans))
return
}
return return
} }
@@ -39,33 +86,53 @@ func (vu verifyUtil) VerifyJSONArray(c *gin.Context, obj any) (e error) {
func (vu verifyUtil) VerifyBody(c *gin.Context, obj any) (e error) { func (vu verifyUtil) VerifyBody(c *gin.Context, obj any) (e error) {
if err := c.ShouldBind(obj); err != nil { if err := c.ShouldBind(obj); err != nil {
errs, ok := err.(validator.ValidationErrors)
if !ok {
e = response.ParamsValidError.MakeData(err.Error()) e = response.ParamsValidError.MakeData(err.Error())
return return
} }
e = response.ParamsValidError.MakeData(errs.Translate(trans))
return
}
return return
} }
func (vu verifyUtil) VerifyHeader(c *gin.Context, obj any) (e error) { func (vu verifyUtil) VerifyHeader(c *gin.Context, obj any) (e error) {
if err := c.ShouldBindHeader(obj); err != nil { if err := c.ShouldBindHeader(obj); err != nil {
errs, ok := err.(validator.ValidationErrors)
if !ok {
e = response.ParamsValidError.MakeData(err.Error()) e = response.ParamsValidError.MakeData(err.Error())
return return
} }
e = response.ParamsValidError.MakeData(errs.Translate(trans))
return
}
return return
} }
func (vu verifyUtil) VerifyQuery(c *gin.Context, obj any) (e error) { func (vu verifyUtil) VerifyQuery(c *gin.Context, obj any) (e error) {
if err := c.ShouldBindQuery(obj); err != nil { if err := c.ShouldBindQuery(obj); err != nil {
errs, ok := err.(validator.ValidationErrors)
if !ok {
e = response.ParamsValidError.MakeData(err.Error()) e = response.ParamsValidError.MakeData(err.Error())
return return
} }
e = response.ParamsValidError.MakeData(errs.Translate(trans))
return
}
return return
} }
func (vu verifyUtil) VerifyFile(c *gin.Context, name string) (file *multipart.FileHeader, e error) { func (vu verifyUtil) VerifyFile(c *gin.Context, name string) (file *multipart.FileHeader, e error) {
file, err := c.FormFile(name) file, err := c.FormFile(name)
if err != nil { if err != nil {
errs, ok := err.(validator.ValidationErrors)
if !ok {
e = response.ParamsValidError.MakeData(err.Error()) e = response.ParamsValidError.MakeData(err.Error())
return return
} }
e = response.ParamsValidError.MakeData(errs.Translate(trans))
return
}
return return
} }