Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
View Source
var CrossDomainHandler = func(ctx *context.Context) { zlog.Info("middleware CrossDomain") ctx.Header("Access-Control-Allow-Origin", ctx.Request().Header.Get("Origin")) ctx.Header("Access-Control-Allow-Headers", "Content-Type,Content-Disposition,X-Request-Id,X-Request-Some") ctx.Header("Access-Control-Expose-Headers", "Content-Length,Access-Control-Allow-Origin,Access-Control-Allow-Headers,Content-Type,cache-control,Set-Auth,Content-Disposition") ctx.Header("Access-Control-Allow-Methods", "GET,POST,OPTIONS,PUT,DELETE,PATCH,HEAD,TRACE") ctx.Header("Access-Control-Allow-Credentials", "true") ctx.Header("Access-Control-Max-Age", "7200") if ctx.Request().Method == "OPTIONS" { ctx.StatusCode(200) } else { ctx.Next() } }
CrossDomainHandler 跨域设置(网关服务用)
View Source
var GlobalRouterHandler = func(ctx *context.Context) { zlog.Info("middleware GlobalRecover") traceId := ctx.GetHeader("X-Request-Id") if traceId == "" { traceId = uuid.New().String() } threadlocal.SetTraceId(traceId) userId := ctx.GetHeader("X-Request-UserId") if userId != "" { threadlocal.SetUserId(userId) } defer func() { if err := recover(); err != nil { if ctx.IsStopped() { return } if tx.IsInTX() { tx.NeedRollback() tx.TryCommit() } var stacktrace string for i := 1; ; i++ { _, f, l, got := runtime.Caller(i) if !got { break } stacktrace += fmt.Sprintf("%s:%d\n", f, l) } errMsg := fmt.Sprintf("%s", err) zlog.Info("异常Ctl入口:{}", ctx.HandlerName()) zlog.Error("ErrorInfo:{}", errMsg) if strings.HasPrefix(errMsg, "") { _ = ctx.JSON(response.Error(common_error.SystemError, errMsg)) } ctx.StatusCode(500) ctx.StopExecution() } }() ctx.Next() if tx.IsInTX() { tx.TryCommit() } }
GlobalRouterHandler 全局路由处理方法
View Source
var NeedLogin = func(ctx *context.Context) { zlog.Info("middleware NeedLogin") userId := ctx.GetHeader("X-Request-UserId") if userId == "" { _ = ctx.JSON(response.Error(common_error.NotLoggedIn, nil)) } else { if userId != "" { threadlocal.SetUserId(userId) ctx.Next() } else { _ = ctx.JSON(response.Error(common_error.NotLoggedIn, nil)) } } }
NeedLogin 拦截器-需要登录(具体路由使用)
View Source
var RouteLogHandler = func(ctx *context.Context) { zlog.Info("middleware Default") zlog.Info("MainHandlerName:{},router:{}", ctx.GetCurrentRoute().MainHandlerName(), ctx.RouteName()) ctx.Next() }
RouteLogHandler 路由打印
View Source
var SaveOpHandler = func(ctx *context.Context) { zlog.Info("middleware SaveOp") if lr, ok := rm.IrisRouterMap[ctx.RouteName()]; ok { if lr.SaveOp { req := &rpc_pbs.UserOperationBehaviorReq{ UserId: threadlocal.GetUserId(), ServerName: common_config.GetAppName(), ApiPath: ctx.RouteName(), EventCode: ctx.GetCurrentRoute().MainHandlerName(), EventName: rm.IrisRouterMap[ctx.RouteName()].Description, ExtendData: "{}", Ipv4: common_utils.RemoteIp(ctx.Request()), Ipv6: "", Device: "未知", UserAgent: ctx.Request().UserAgent(), SomeId: ctx.Request().Header.Get("X-Request-Some"), TraceId: threadlocal.GetTraceId(), BehaviorTime: time.Now().Format(common_const.DataFormat), } traceId := threadlocal.GetTraceId() _ = common_goroutine.GetNonBlockingAntsPool().Submit(func() { threadlocal.SetTraceId(traceId) universal.SaveUserOperationBehavior(req) }) } } ctx.Next() }
SaveOpHandler 保存操作记录
Functions ¶
This section is empty.
Types ¶
This section is empty.
Click to show internal directories.
Click to hide internal directories.