middleware.go 3.8 KB

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