2 回答

TA貢獻1780條經驗 獲得超4個贊
您可以使用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 關注
- 108 瀏覽
添加回答
舉報