endecrypt.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. // 中间件模块-参数加解密
  2. // 秒寻科技
  3. // 2024-02-18
  4. // 周涛
  5. package endecrypt
  6. import (
  7. "bytes"
  8. "encoding/json"
  9. "io"
  10. "ipsomc/util"
  11. "net/http"
  12. "github.com/gin-gonic/gin"
  13. )
  14. // 解密请求参数
  15. func DecryptReqParam() func(c *gin.Context) {
  16. return func(c *gin.Context) {
  17. //请求中有路由参数
  18. urlParam := c.Request.URL.RawQuery //请求中的路由参数
  19. if urlParam != "" {
  20. //参数解密
  21. res, err := util.DecryptAes(urlParam)
  22. if err != nil {
  23. c.String(http.StatusBadRequest, err.Error())
  24. c.Abort()
  25. return
  26. }
  27. c.Request.URL.RawQuery = res //将解密后的路由参数回写到请求中
  28. }
  29. //body中有参数
  30. bodyData, err := io.ReadAll(c.Request.Body)
  31. if err != nil {
  32. c.String(http.StatusBadRequest, err.Error())
  33. c.Abort()
  34. return
  35. }
  36. defer c.Request.Body.Close()
  37. if len(bodyData) == 0 {
  38. c.Next()
  39. return
  40. }
  41. plainBuf, err := util.DecryptAes(string(bodyData))
  42. if err != nil {
  43. c.String(http.StatusBadRequest, err.Error())
  44. c.Abort()
  45. return
  46. }
  47. r := bytes.NewBuffer([]byte(plainBuf))
  48. rd := io.NopCloser(r)
  49. c.Request.Body = rd //将解密参数回写到请求中
  50. }
  51. }
  52. // 移动端解密请求参数
  53. func MobileDecryptReqParam() func(c *gin.Context) {
  54. return func(c *gin.Context) {
  55. ////解密请求头
  56. authorizationParam := c.Request.Header.Get("Authorization")
  57. if authorizationParam != "" {
  58. type headers struct {
  59. Rnd string `json:"rnd"`
  60. Token string `json:"token"`
  61. }
  62. var myHead headers
  63. resp, err := util.DecryptAes(authorizationParam)
  64. if err != nil {
  65. c.String(http.StatusBadRequest, err.Error())
  66. c.Abort()
  67. return
  68. }
  69. if err := json.Unmarshal([]byte(resp), &myHead); err != nil {
  70. c.String(http.StatusBadRequest, err.Error())
  71. c.Abort()
  72. return
  73. }
  74. c.Request.Header.Set("Authorization", myHead.Token)
  75. }
  76. ////解密路由参数,就是get请求的参数
  77. urlParam := c.Request.URL.RawQuery //请求中的路由参数
  78. if urlParam != "" {
  79. //参数解密
  80. res, err := util.DecryptAes(urlParam)
  81. if err != nil {
  82. c.String(http.StatusBadRequest, err.Error())
  83. c.Abort()
  84. return
  85. }
  86. c.Request.URL.RawQuery = res //将解密后的路由参数回写到请求中
  87. }
  88. ////解密body参数,就是post请求的参数
  89. bodyData, err := io.ReadAll(c.Request.Body)
  90. if err != nil {
  91. c.String(http.StatusBadRequest, err.Error())
  92. c.Abort()
  93. return
  94. }
  95. defer c.Request.Body.Close()
  96. if len(bodyData) == 0 {
  97. c.Next()
  98. return
  99. }
  100. plainBuf, err := util.DecryptAes(string(bodyData))
  101. if err != nil {
  102. c.String(http.StatusBadRequest, err.Error())
  103. c.Abort()
  104. return
  105. }
  106. r := bytes.NewBuffer([]byte(plainBuf))
  107. rd := io.NopCloser(r)
  108. c.Request.Body = rd //将解密参数回写到请求中
  109. }
  110. }