自訂 Go 程式中的代理程式使用
為了自動配置 Go 程式以使用代理,http.Client 類型提供了 ProxyFromEnvironment 方法。此方法檢查 HTTP_PROXY 和 HTTPS_PROXY 環境變數以確定適當的代理 URL。
在提供的程式碼片段中:
<code class="go">tr := &http.Transport{ TLSClientConfig: &tls.Config{InsecureSkipVerify: true}, } client := &http.Client{Transport: tr} resp, err := client.Get(url)</code>
建立的傳輸不考慮代理設定。若要啟用代理程式使用,請使用 ProxyFromEnvironment 方法:
<code class="go">var PTransport = &http.Transport{ Proxy: http.ProxyFromEnvironment, } client := http.Client{ Transport: PTransport, }</code>
ProxyFromEnvironment 傳回從環境變數衍生的代理 URL,優先考慮 HTTPS 要求的 HTTPS_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'
提供的程式碼範例對遠端API 執行GET 要求,並示範了代理設定的成功整合:
<code class="go">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)) }</code>
以上是如何配置 Go 程式以使用自訂代理程式?的詳細內容。更多資訊請關注PHP中文網其他相關文章!