Skip to main content

Client

概述

HTTP Client 是一个用于发送 HTTP 请求的库,它支持如下功能:

  1. Content-Type 自动识别,仅支持 application/jsonapplication/x-www-form-urlencoded 两种格式
  2. 支持将 path 参数自动填充到 url
  3. 支持将结构体中 header 填充到 http 请求头

请求示例

GET、POST Form 请求

Get 和 Post form 请求的使用方式是一样的,只需要将结构体中的字段标记为 form 即可。

type Request struct {
Node string `path:"node"`
ID int `form:"id"`
Header string `header:"X-Header"`
}

var domain = flag.String("domain", "http://localhost:3333", "the domain to request")

func main() {
flag.Parse()

req := Request{
Node: "foo",
ID: 1024,
Header: "foo-header",
}
resp, err := httpc.Do(context.Background(), http.MethodGet, *domain+"/nodes/:node", req)
// resp, err := httpc.Do(context.Background(), http.MethodPost, *domain+"/nodes/:node", req)
if err != nil {
fmt.Println(err)
return
}

io.Copy(os.Stdout, resp.Body)
}

以上内等同于如下 curl:

# get
curl --location 'http://localhost:3333/nodes/foo?id=1024' \
--header 'X-Header: foo-header'

# post
curl --location 'http://localhost:3333/nodes/foo' \
--header 'X-Header: foo-header' \
--header 'Content-Type: application/x-www-form-urlencoded' \
--data-urlencode 'id=1024'

POST Json 请求

Post Json 请求的使用方式是一样的,只需要将结构体中的字段标记为 json 即可。

type Request struct {
Node string `path:"node"`
Foo string `json:"foo"`
Bar string `json:"bar"`
Header string `header:"X-Header"`
}

var domain = flag.String("domain", "http://localhost:3333", "the domain to request")

func main() {
flag.Parse()

req := Request{
Node: "foo",
Header: "foo-header",
Foo: "foo",
Bar: "bar",
}
resp, err := httpc.Do(context.Background(), http.MethodPost, *domain+"/nodes/:node", req)
if err != nil {
fmt.Println(err)
return
}

io.Copy(os.Stdout, resp.Body)
}

以上请求等同于如下 curl:

curl --location 'http://localhost:3333/nodes/foo' \
--header 'X-Header: foo-header' \
--header 'Content-Type: application/json' \
--data '{
"foo":"foo",
"bar":"bar"
}'
温馨提示

httpc 默认使用的是 http.DefaultClient,如需要自定义 client,请使用 httpc.NewServiceWithClient