mirror of
https://gitee.com/xiangheng/x_admin.git
synced 2025-10-10 18:40:17 +08:00
fix:修改用户信息密码不用必传
This commit is contained in:
@@ -45,10 +45,10 @@ type SystemAuthAdminEditReq struct {
|
|||||||
|
|
||||||
//SystemAuthAdminUpdateReq 管理员更新参数
|
//SystemAuthAdminUpdateReq 管理员更新参数
|
||||||
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 管理员删除参数
|
||||||
|
@@ -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 {
|
||||||
|
@@ -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,7 +59,12 @@ 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 {
|
||||||
e = response.ParamsValidError.MakeData(err.Error())
|
errs, ok := err.(validator.ValidationErrors)
|
||||||
|
if !ok {
|
||||||
|
e = response.ParamsValidError.MakeData(err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
e = response.ParamsValidError.MakeData(errs.Translate(trans))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
@@ -39,7 +86,12 @@ 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 {
|
||||||
e = response.ParamsValidError.MakeData(err.Error())
|
errs, ok := err.(validator.ValidationErrors)
|
||||||
|
if !ok {
|
||||||
|
e = response.ParamsValidError.MakeData(err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
e = response.ParamsValidError.MakeData(errs.Translate(trans))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
@@ -47,7 +99,12 @@ func (vu verifyUtil) VerifyBody(c *gin.Context, obj any) (e error) {
|
|||||||
|
|
||||||
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 {
|
||||||
e = response.ParamsValidError.MakeData(err.Error())
|
errs, ok := err.(validator.ValidationErrors)
|
||||||
|
if !ok {
|
||||||
|
e = response.ParamsValidError.MakeData(err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
e = response.ParamsValidError.MakeData(errs.Translate(trans))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
@@ -55,7 +112,12 @@ func (vu verifyUtil) VerifyHeader(c *gin.Context, obj any) (e error) {
|
|||||||
|
|
||||||
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 {
|
||||||
e = response.ParamsValidError.MakeData(err.Error())
|
errs, ok := err.(validator.ValidationErrors)
|
||||||
|
if !ok {
|
||||||
|
e = response.ParamsValidError.MakeData(err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
e = response.ParamsValidError.MakeData(errs.Translate(trans))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
@@ -64,7 +126,12 @@ func (vu verifyUtil) VerifyQuery(c *gin.Context, obj any) (e error) {
|
|||||||
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 {
|
||||||
e = response.ParamsValidError.MakeData(err.Error())
|
errs, ok := err.(validator.ValidationErrors)
|
||||||
|
if !ok {
|
||||||
|
e = response.ParamsValidError.MakeData(err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
e = response.ParamsValidError.MakeData(errs.Translate(trans))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
|
Reference in New Issue
Block a user