HTTP
客户端发起请求时可以自定义发送给服务端的Header
内容,该特性使用SetHeader*
相关方法实现。
方法列表:
func (c *Client) SetHeader(key, value string) *Client
func (c *Client) SetHeaderMap(m map[string]string) *Client
func (c *Client) SetHeaderRaw(headers string) *Client
我们来看一个客户端通过Header
来自定义发送自定义链路跟踪信息Span-Id
及Trace-Id
消息头的示例。
package main
import (
"github.com/gogf/gf/v2/frame/g"
"github.com/gogf/gf/v2/net/ghttp"
)
func main() {
s := g.Server()
s.BindHandler("/", func(r *ghttp.Request) {
r.Response.Writef(
"Span-Id:%s,Trace-Id:%s",
r.Header.Get("Span-Id"),
r.Header.Get("Trace-Id"),
)
})
s.SetPort(8199)
s.Run()
}
由于是作为示例,服务端的逻辑很简单,直接将接收到的Span-Id
及Trace-Id
参数返回给客户端。
SetHeader
方法package main
import (
"fmt"
"github.com/gogf/gf/v2/frame/g"
"github.com/gogf/gf/v2/os/gctx"
)
func main() {
c := g.Client()
c.SetHeader("Span-Id", "0.0.1")
c.SetHeader("Trace-Id", "NBC56410N97LJ016FQA")
if r, e := c.Get(gctx.New(), "http://127.0.0.1:8199/"); e != nil {
panic(e)
} else {
fmt.Println(r.ReadAllString())
}
}
通过g.Client()
创建一个自定义的HTTP
请求客户端对象,并通过c.SetHeader
设置自定义的Header
信息。
SetHeaderRaw
方法
这个方法更加简单,可以通过原始的Header
字符串来设置客户端请求Header
。
package main
import (
"fmt"
"github.com/gogf/gf/v2/frame/g"
"github.com/gogf/gf/v2/os/gctx"
)
func main() {
c := g.Client()
c.SetHeaderRaw(`
Referer: https://localhost
Span-Id: 0.0.1
Trace-Id: NBC56410N97LJ016FQA
User-Agent: MyTestClient
`)
if r, e := c.Get(gctx.New(), "http://127.0.0.1:8199/"); e != nil {
panic(e)
} else {
fmt.Println(r.ReadAllString())
}
}
客户端代码执行后,终端将会打印出服务端的返回结果,如下:
Span-Id:0.0.1,Trace-Id:NBC56410N97LJ016FQA
Tornado Web 应用程序通常由一个或多个 RequestHandler子类,一个Application将传入请求路由到处理程序的对象和一个main()启...
用于生成本地化字符串的翻译方法。要加载语言环境并生成翻译的字符串:user_locale = tornado.locale.get("es_LA")print(user_lo...
FastAPI允许你为参数声明额外的信息和校验。让我们以下面的应用程序为例:from typing import Optionalfrom fastapi import Fast...
Flask- 概述什么是Web框架?Web应用程序框架或简单的Web框架表示一组库和模块,使Web应用程序开发人员能够编写应用程序,而不必...
蓝图的基本设想是当它们注册到应用上时,它们记录将会被执行的操作。 当分派请求和生成从一个端点到另一个的 URL 时,Flask 会关...