middleware.go 3.7 KB

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