Introduction

In request processes, some custom set variables are often shared in the context, such as setting some variables through middleware before the request starts, which can then be accessed in the routing service method for corresponding processing. This requirement is very common. In the GoFrame framework, we recommend using the Context context object to handle context variables shared in the process, even passing this object further into various dependent module methods. The Context object type implements the standard library’s context.Context API, which is often used as the first parameter of module inter-call methods, and this API parameter is also the recommended way by Golang official to pass context variables between modules.

Method List:

  1. func (r *Request) GetCtx() context.Context
  2. func (r *Request) SetCtx(ctx context.Context)
  3. func (r *Request) GetCtxVar(key interface{}, def ...interface{}) *gvar.Var
  4. func (r *Request) SetCtxVar(key interface{}, value interface{})

Brief Explanation:

  1. The GetCtx method is used to get the current context.Context object, serving the same purpose as the Context method.
  2. The SetCtx method is used to set a custom context.Context context object.
  3. The GetCtxVar method is used to get the context variable and can provide a default value if the variable does not exist.
  4. The SetCtxVar method is used to set the context variable.

Usage Example

Example 1, SetCtxVar/GetCtxVar

  1. package main
  2. import (
  3. "github.com/gogf/gf/v2/frame/g"
  4. "github.com/gogf/gf/v2/net/ghttp"
  5. )
  6. const (
  7. TraceIdName = "trace-id"
  8. )
  9. func main() {
  10. s := g.Server()
  11. s.Group("/", func(group *ghttp.RouterGroup) {
  12. group.Middleware(func(r *ghttp.Request) {
  13. r.SetCtxVar(TraceIdName, "HBm876TFCde435Tgf")
  14. r.Middleware.Next()
  15. })
  16. group.ALL("/", func(r *ghttp.Request) {
  17. r.Response.Write(r.GetCtxVar(TraceIdName))
  18. })
  19. })
  20. s.SetPort(8199)
  21. s.Run()
  22. }

As you can see, we can use SetCtxVar and GetCtxVar to set and get custom variables, and the lifecycle of these variables is limited to the current request process.

After execution, access http://127.0.0.1:8199/, and the page output is:

  1. HBm876TFCde435Tgf

Example 2, SetCtx

The SetCtx method is often used in middleware to integrate some third-party components, such as third-party tracing components.

To simplify the example, let’s modify the above example using the SetCtx method for demonstration.

  1. package main
  2. import (
  3. "context"
  4. "github.com/gogf/gf/v2/frame/g"
  5. "github.com/gogf/gf/v2/net/ghttp"
  6. )
  7. const (
  8. TraceIdName = "trace-id"
  9. )
  10. func main() {
  11. s := g.Server()
  12. s.Group("/", func(group *ghttp.RouterGroup) {
  13. group.Middleware(func(r *ghttp.Request) {
  14. ctx := context.WithValue(r.Context(), TraceIdName, "HBm876TFCde435Tgf")
  15. r.SetCtx(ctx)
  16. r.Middleware.Next()
  17. })
  18. group.ALL("/", func(r *ghttp.Request) {
  19. r.Response.Write(r.Context().Value(TraceIdName))
  20. // Alternatively, you can use
  21. // r.Response.Write(r.GetCtxVar(TraceIdName))
  22. })
  23. })
  24. s.SetPort(8199)
  25. s.Run()
  26. }

After execution, access http://127.0.0.1:8199/, and the page output is:

  1. HBm876TFCde435Tgf