2 回答
TA贡献1780条经验 获得超3个赞
您可以使用http.ProxyFromEnvironment方法
var PTransport = & http.Transport { Proxy: http.ProxyFromEnvironment }
client: = http.Client { Transport: PTransport }
ProxyFromEnvironment 返回用于给定请求的代理的 URL,如环境变量 HTTP_PROXY、HTTPS_PROXY 和 NO_PROXY(或其小写版本)所示。对于 https 请求,HTTPS_PROXY 优先于 HTTP_PROXY。
我试过下面的代码,它有效,只需在终端中添加你的代理详细信息。
export http_proxy='http://user:password@prox-server:3128'
export https_proxy='http://user:password@prox-server:3128'
export HTTP_PROXY='http://user:password@prox-server:3128'
export HTTPS_PROXY='http://user:password@prox-server:3128'
package main
import (
"fmt"
"net/http"
"io/ioutil"
)
func main() {
var PTransport = & http.Transport {
Proxy: http.ProxyFromEnvironment
}
client: = http.Client {
Transport: PTransport
}
req, err: = http.NewRequest("GET", "https://jsonplaceholder.typicode.com/todos/1", nil)
req.Header.Add("If-None-Match", `some value`)
resp, err: = client.Do(req)
if err != nil {
panic(err)
}
defer resp.Body.Close()
bodyBytes, err: = ioutil.ReadAll(resp.Body)
if err != nil {
panic(err)
}
bodyString: = string(bodyBytes)
fmt.Printf("GET Response = %s \n", string(bodyString))
}
TA贡献1876条经验 获得超5个赞
将传输代理字段设置为http.ProxyFromEnvironment以使用从环境变量配置的代理:
tr := &http.Transport{ Proxy: ProxyFromEnvironment, TLSClientConfig: &tls.Config{InsecureSkipVerify: true}, }
通常最好克隆默认传输并在该传输中设置您的选项:
tr := http.DefaultTransport.(*http.Transport).Clone() tr.TLSClientConfig = &tls.Config{InsecureSkipVerify: true} client := &http.Client{Transport: tr} resp, err := client.Get(url)
默认传输包括代理字段、超时和其他有用设置的正确值。
如果应用程序没有创建自定义传输,则不需要这些来支持与代理相关的环境变量。
- 2 回答
- 0 关注
- 85 浏览
添加回答
举报