errorHandler.go 931 B

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