errorHandler.go 934 B

12345678910111213141516171819202122232425262728293031
  1. package middleware
  2. import (
  3. . "bp.jydev.jianyu360.cn/BaseService/gateway/common/gatecode"
  4. "bp.jydev.jianyu360.cn/BaseService/gateway/core/logs"
  5. "github.com/gogf/gf/v2/errors/gcode"
  6. "github.com/gogf/gf/v2/errors/gerror"
  7. "github.com/gogf/gf/v2/net/ghttp"
  8. )
  9. // ErrorHandler 统一异常拦截、提醒,及日志打印中间件
  10. func ErrorHandler(r *ghttp.Request) {
  11. r.Middleware.Next()
  12. // 程序异常信息处理
  13. err := r.GetError()
  14. if err != nil {
  15. gCode := gerror.Code(err)
  16. if gCode == gcode.CodeNil { // 非定义异常
  17. gCode = gcode.New(int(OTHER_ERR_UNDEFINED), OTHER_ERR_UNDEFINED.String(), err.Error())
  18. err = gerror.NewCode(gCode, "非定义异常")
  19. }
  20. // 返回固定的友好信息
  21. r.Response.ClearBuffer()
  22. r.Response.Write(map[string]interface{}{
  23. "error_code": gCode.Code(),
  24. "error_msg": gCode.Message(),
  25. })
  26. }
  27. // 记录到日志文件并通知
  28. go logs.GReq.RecordLogAndNotice(r, err)
  29. }