middleware.go 4.1 KB

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