bind.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. // gin绑定参数模块
  2. // 秒寻科技
  3. // zt 2024-01-05
  4. package bind
  5. import (
  6. "bytes"
  7. "encoding/json"
  8. "errors"
  9. "io"
  10. "ipsomc/core/dao/mysql/mysqlmodel"
  11. "ipsomc/core/dao/redis/redismodel"
  12. "reflect"
  13. "github.com/gin-gonic/gin"
  14. )
  15. type BindApi struct{}
  16. // 绑定body中的参数
  17. func (obj BindApi) bindBodyData(c *gin.Context, dataModel interface{}) error {
  18. //读取body参数后,参数将被清空
  19. bodyData, err := io.ReadAll(c.Request.Body)
  20. if err != nil {
  21. return err
  22. }
  23. defer c.Request.Body.Close()
  24. //body中没有数据
  25. if len(bodyData) <= 0 {
  26. return nil
  27. }
  28. //回写参数至body,以便执行bind
  29. r := bytes.NewBuffer(bodyData)
  30. rd := io.NopCloser(r)
  31. c.Request.Body = rd
  32. //绑定参数到模型
  33. if err := c.ShouldBindJSON(dataModel); err != nil {
  34. return errors.New("数据解析错误")
  35. }
  36. return nil
  37. }
  38. // 增加用户信息,包括用户ID、公司ID和项目信息
  39. func (obj BindApi) AddUserInfo(c *gin.Context, dataModel interface{}) error {
  40. var redisModel redismodel.RedisOperator
  41. modelTmp, ok := c.Get("mycontext") //获得“mycontent”的值
  42. if ok {
  43. dataList, err := json.Marshal(modelTmp)
  44. if err != nil {
  45. return err
  46. }
  47. if err := json.Unmarshal(dataList, &redisModel); err != nil {
  48. return err
  49. }
  50. //将用户基本信息补充到模型中
  51. val := reflect.ValueOf(dataModel).Elem()
  52. val.FieldByName("CompanyID").SetInt(int64(redisModel.CompanyID))
  53. val.FieldByName("ProjectID").SetInt(int64(redisModel.ProjectID))
  54. val.FieldByName("OwnerID").SetInt(int64(redisModel.UserID))
  55. }
  56. return nil
  57. }
  58. // 绑定数据到模型
  59. func (obj BindApi) Bind2Model(c *gin.Context, dataModel interface{}) error {
  60. if err := obj.bindBodyData(c, dataModel); err != nil {
  61. return err
  62. }
  63. //增加用户信息到模型
  64. if err := obj.AddUserInfo(c, dataModel); err != nil {
  65. return errors.New(err.Error())
  66. }
  67. return nil
  68. }
  69. // 绑定参数到map,用于修改模型
  70. func (obj BindApi) Bind2Map(c *gin.Context, dataModel interface{}, dataMap map[string]interface{}) error {
  71. //将数据绑定到map中(只获得前端传过来的数据)
  72. if err := c.ShouldBindJSON(&dataMap); err != nil {
  73. return err
  74. }
  75. //将map转成结构体,以便填充dataModel
  76. dataList, err := json.Marshal(dataMap)
  77. if err != nil {
  78. return err
  79. }
  80. //填充dataModel(组要是填充ID值)
  81. if err := json.Unmarshal(dataList, dataModel); err != nil {
  82. return err
  83. }
  84. //从map中删除ID键
  85. for key := range dataMap {
  86. if key == "id" {
  87. delete(dataMap, key)
  88. break
  89. }
  90. }
  91. //增加用户信息到模型
  92. if err := obj.AddUserInfo(c, dataModel); err != nil {
  93. return errors.New(err.Error())
  94. }
  95. return nil
  96. }
  97. // 绑定参数到查询条件
  98. func (obj BindApi) Bind2Query(c *gin.Context, queryParam interface{}) error {
  99. if err := obj.bindBodyData(c, queryParam); err != nil {
  100. return err
  101. }
  102. //增加用户信息到模型
  103. if err := obj.AddUserInfo(c, queryParam); err != nil {
  104. return errors.New(err.Error())
  105. }
  106. return nil
  107. }
  108. // 绑定数据到分页查询条件
  109. func (obj BindApi) Bind2PageQuery(c *gin.Context, pageQueryParam *mysqlmodel.PageListParam) error {
  110. if err := obj.bindBodyData(c, pageQueryParam); err != nil {
  111. return err
  112. }
  113. //增加用户信息到模型
  114. if err := obj.AddUserInfo(c, pageQueryParam); err != nil {
  115. return errors.New(err.Error())
  116. }
  117. return nil
  118. }