mirror of
https://gitee.com/xiangheng/x_admin.git
synced 2025-10-10 18:40:17 +08:00
fix:修改用户信息密码不用必传
This commit is contained in:
@@ -47,8 +47,8 @@ type SystemAuthAdminEditReq struct {
|
||||
type SystemAuthAdminUpdateReq struct {
|
||||
Nickname string `form:"nickname" binding:"required,min=2,max=30"` // 昵称
|
||||
Avatar string `form:"avatar"` // 头像
|
||||
Password string `form:"password" binding:"required"` // 密码
|
||||
CurrPassword string `form:"currPassword" binding:"required,min=6,max=32"` // 密码
|
||||
Password string `form:"password" binding:""` // 密码
|
||||
CurrPassword string `form:"currPassword" binding:""` // 密码
|
||||
}
|
||||
|
||||
//SystemAuthAdminDelReq 管理员删除参数
|
||||
|
@@ -308,7 +308,7 @@ func (adminSrv systemAuthAdminService) Update(c *gin.Context, updateReq SystemAu
|
||||
avatar = updateReq.Avatar
|
||||
}
|
||||
adminMap["Avatar"] = util.UrlUtil.ToRelativeUrl(avatar)
|
||||
delete(adminMap, "aaa")
|
||||
// delete(adminMap, "aaa")
|
||||
if updateReq.Password != "" {
|
||||
currPass := util.ToolsUtil.MakeMd5(updateReq.CurrPassword + admin.Salt)
|
||||
if currPass != admin.Password {
|
||||
|
@@ -2,14 +2,56 @@ package util
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
"io"
|
||||
"mime/multipart"
|
||||
"x_admin/core/response"
|
||||
|
||||
"github.com/gin-gonic/gin"
|
||||
"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{}
|
||||
|
||||
// verifyUtil 参数验证工具类
|
||||
@@ -17,9 +59,14 @@ type verifyUtil struct{}
|
||||
|
||||
func (vu verifyUtil) VerifyJSON(c *gin.Context, obj any) (e error) {
|
||||
if err := c.ShouldBindBodyWith(obj, binding.JSON); err != nil {
|
||||
errs, ok := err.(validator.ValidationErrors)
|
||||
if !ok {
|
||||
e = response.ParamsValidError.MakeData(err.Error())
|
||||
return
|
||||
}
|
||||
e = response.ParamsValidError.MakeData(errs.Translate(trans))
|
||||
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) {
|
||||
if err := c.ShouldBind(obj); err != nil {
|
||||
errs, ok := err.(validator.ValidationErrors)
|
||||
if !ok {
|
||||
e = response.ParamsValidError.MakeData(err.Error())
|
||||
return
|
||||
}
|
||||
e = response.ParamsValidError.MakeData(errs.Translate(trans))
|
||||
return
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
func (vu verifyUtil) VerifyHeader(c *gin.Context, obj any) (e error) {
|
||||
if err := c.ShouldBindHeader(obj); err != nil {
|
||||
errs, ok := err.(validator.ValidationErrors)
|
||||
if !ok {
|
||||
e = response.ParamsValidError.MakeData(err.Error())
|
||||
return
|
||||
}
|
||||
e = response.ParamsValidError.MakeData(errs.Translate(trans))
|
||||
return
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
func (vu verifyUtil) VerifyQuery(c *gin.Context, obj any) (e error) {
|
||||
if err := c.ShouldBindQuery(obj); err != nil {
|
||||
errs, ok := err.(validator.ValidationErrors)
|
||||
if !ok {
|
||||
e = response.ParamsValidError.MakeData(err.Error())
|
||||
return
|
||||
}
|
||||
e = response.ParamsValidError.MakeData(errs.Translate(trans))
|
||||
return
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
func (vu verifyUtil) VerifyFile(c *gin.Context, name string) (file *multipart.FileHeader, e error) {
|
||||
file, err := c.FormFile(name)
|
||||
if err != nil {
|
||||
errs, ok := err.(validator.ValidationErrors)
|
||||
if !ok {
|
||||
e = response.ParamsValidError.MakeData(err.Error())
|
||||
return
|
||||
}
|
||||
e = response.ParamsValidError.MakeData(errs.Translate(trans))
|
||||
return
|
||||
}
|
||||
return
|
||||
}
|
||||
|
Reference in New Issue
Block a user