middleware.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. package middleware
  2. import (
  3. "context"
  4. "jyOrderManager/internal/model"
  5. "jyOrderManager/internal/service"
  6. "sync"
  7. "jyOrderManager/utility"
  8. "net/http"
  9. "time"
  10. util "app.yhyue.com/moapp/jybase/common"
  11. "github.com/gogf/gf/v2/errors/gcode"
  12. "github.com/gogf/gf/v2/errors/gerror"
  13. "github.com/gogf/gf/v2/frame/g"
  14. "github.com/gogf/gf/v2/net/ghttp"
  15. )
  16. type sMiddleware struct {
  17. }
  18. var (
  19. logArr = []map[string]interface{}{}
  20. logLock = &sync.Mutex{}
  21. logSaveCount int
  22. )
  23. func init() {
  24. logSaveCount = g.Cfg().MustGet(context.Background(), "logger.logSaveCount", 500).Int()
  25. service.RegisterMiddleware(&sMiddleware{})
  26. }
  27. // 定时保存日志
  28. func SaveLogTask() {
  29. logLock.Lock()
  30. if len(logArr) >= 1 {
  31. tmpArr := logArr
  32. logArr = make([]map[string]interface{}, 0)
  33. go func() {
  34. g.Log().Info(context.TODO(), "timer..save..visit..log", len(tmpArr))
  35. utility.MG.DB("log").SaveBulk("jy_seo_logs", tmpArr...)
  36. }()
  37. }
  38. logLock.Unlock()
  39. time.AfterFunc(5*time.Minute, SaveLogTask)
  40. }
  41. // 访问日志
  42. func (s *sMiddleware) Log(r *ghttp.Request) {
  43. timeNow := time.Now()
  44. data := map[string]interface{}{
  45. "date": timeNow.Unix(),
  46. "ip": r.GetClientIp(),
  47. "refer": r.Referer(),
  48. "year": timeNow.Year(),
  49. "month": timeNow.Month(),
  50. "day": timeNow.Day(),
  51. "hour": timeNow.Hour(),
  52. "minutes": timeNow.Minute(),
  53. "mdescribe": r.GetBodyString(),
  54. "client": r.UserAgent(),
  55. "os": util.GetOS(r.UserAgent()),
  56. "browse": util.GetBrowse(r.UserAgent()),
  57. "method": r.Method,
  58. "url": r.RequestURI,
  59. }
  60. if userId, err := r.Session.Get("userId"); err == nil && !userId.IsEmpty() {
  61. data["userid"] = userId.String()
  62. }
  63. logLock.Lock()
  64. logArr = append(logArr, data)
  65. if len(logArr) >= logSaveCount {
  66. tmpArr := logArr
  67. logArr = make([]map[string]interface{}, 0)
  68. go func() {
  69. g.Log().Info(r.Context(), "save..visit..log", len(tmpArr))
  70. utility.MG.DB("log").SaveBulk("jy_seo_logs", tmpArr...)
  71. }()
  72. }
  73. logLock.Unlock()
  74. r.Middleware.Next()
  75. }
  76. // Ctx 获取用户身份
  77. func (s *sMiddleware) Ctx(r *ghttp.Request) {
  78. r.Middleware.Next()
  79. }
  80. // LoginFilter 登录过滤拦截
  81. func (s *sMiddleware) LoginFilter(r *ghttp.Request) {
  82. r.Middleware.Next()
  83. }
  84. // CORS 允许跨域请求
  85. func (s *sMiddleware) CORS(r *ghttp.Request) {
  86. r.Response.CORSDefault()
  87. r.Middleware.Next()
  88. }
  89. // MiddlewareHandlerResponse is the default middleware handling handler response object and its error.
  90. func (s *sMiddleware) MiddlewareHandlerResponse(r *ghttp.Request) {
  91. r.Middleware.Next()
  92. // There's custom buffer content, it then exits current handler.
  93. if r.Response.BufferLength() > 0 {
  94. return
  95. }
  96. var (
  97. msg string
  98. err = r.GetError()
  99. res = r.GetHandlerResponse()
  100. code = gerror.Code(err)
  101. )
  102. if err != nil {
  103. if code == gcode.CodeNil {
  104. code = gcode.CodeInternalError
  105. }
  106. msg = err.Error()
  107. } else {
  108. if r.Response.Status > 0 && r.Response.Status != http.StatusOK {
  109. msg = http.StatusText(r.Response.Status)
  110. switch r.Response.Status {
  111. case http.StatusNotFound:
  112. code = gcode.CodeNotFound
  113. case http.StatusForbidden:
  114. code = gcode.CodeNotAuthorized
  115. default:
  116. code = gcode.CodeUnknown
  117. }
  118. // It creates error as it can be retrieved by other middlewares.
  119. err = gerror.NewCode(code, msg)
  120. r.SetError(err)
  121. } else {
  122. code = gcode.CodeOK
  123. }
  124. }
  125. r.Response.WriteJson(model.DefaultResponse{
  126. Code: code.Code(),
  127. Message: msg,
  128. Data: res,
  129. })
  130. }