golang中發送http請求的幾種常見情況

來源:互聯網
上載者:User
這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。

整理一下golang中各種http的發送方式

最初的一些項目中,很多的地方都使用到了golang發送http請求,之後再對請求收到的結果進行一些處理,所用到的模式也比較固定,這裡整理一下集中http的發送方式,先記錄這麼多,再一點一點添加。

最基本的情境

方式一 使用http.Newrequest

先產生http.client -> 再產生 http.request -> 之後提交請求:client.Do(request) -> 處理返回結果,每一步的過程都可以設定一些具體的參數,下面是一個最樸素最基本的例子:

//question ???將stdout重新導向為response資訊???package mainimport ("fmt""io""net/http""os")func main() {    //產生client 參數為預設client := &http.Client{}//產生要訪問的urlurl := "http://www.baidu.com"    //提交請求reqest, err := http.NewRequest("GET", url, nil)if err != nil {panic(err)}//處理返回結果response, _ := client.Do(reqest)      //將結果定位到標準輸出 也可以直接列印出來 或者定位到其他地方進行相應的處理stdout := os.Stdout_, err = io.Copy(stdout, response.Body)      //返回的狀態代碼status := response.StatusCodefmt.Println(status)}

方式二 先產生client,之後用client.get/post..

client結構自己也有一些發送api的方法,比如client.get,client.post,client.postform..等等。基本上涵蓋了主要的http請求的類型,通常不進行什麼特殊的配置的話,這樣就可以了,其實client的get或者post方法,也是對http.Newerequest方法的封裝,裡面還額外添加了req.Header.Set("Content-Type", bodyType)一般用的話,也是ok的

方式三 http. Get/Post..

具體實現的時候,還是採用的先前提到的模式,先產生一個預設的client,之後調用http.Newrequest方法。

對每個步驟進行細節性的說明

產生client時候的參數配置

最常見的一個參數是使用https的方式發送資訊時候client端的設定。如果產生client的時候,什麼資訊都不添加,就會使用預設的值。具體的資訊包括:

Transport RoundTripperCheckRedirect func(req *Request, via []*Request) errorJar CookieJarTimeout time.Duration

第一個參數是一個RoundTripper介面,裡麵包含了一個RoundTrip函數,指定了一些http請求的基本機制。http.Transport中涉及到的參數較多,要是不指定的話,就會使用預設的DefaultTransport參數,裡麵包含一些預設的請求時間以及proxy機制之類的。具體的細節參數涉及到好多,有的都沒有使用到過比如那些我握手時間之類的,目前使用到的最多的就是https的相關參數:TLSClientConfig,這是一個*tls.Config類型,其中涉及到的參數還是有很多,一個基本的是用案例如下,僅僅是在配置中制定了rooca以及客戶度端使用的認證。相關的https的內容可以參考之前的這一篇

通常發送https請求的時候,前面的參數可以使用如下方式進行處理:

    pool := x509.NewCertPool()caCertPath := "certs/cert_server/ca.crt"caCrt, err := ioutil.ReadFile(caCertPath)if err != nil {fmt.Println("ReadFile err:", err)return}pool.AppendCertsFromPEM(caCrt)cliCrt, err := tls.LoadX509KeyPair("certs/cert_server/client.crt", "certs/cert_server/client.key")if err != nil {fmt.Println("Loadx509keypair err:", err)return}tr := &http.Transport{TLSClientConfig: &tls.Config{RootCAs:      pool,Certificates: []tls.Certificate{cliCrt},},}client := &http.Client{Transport: tr}

產生request時候的參數配置

產生request的時候,主要的是幾個基本的參數。NewRequest函數有三個基本的參數,NewRequest(method, urlStr string, body io.Reader)第一個是請求的類型,GET, POST, PUT, etc.要設成大寫的形式。第二個參數是請求要訪問的url,第三個參數是請求的body中的內容,需要是一個io.Reader的類型。

注意io.Reader的介面中是一個Read方法,實現了Read方法的類型應該都可以作為io.Reader來返回,Read(p []byte) (n int, err error)函數具體的功能就是讀入len(p)長度的內容到p中,返回讀入的長度以及錯誤資訊。

通常是採用strings.NewReader函數,將一個string類型轉化為io.Reader類型,或者bytes.NewBuffer函數,將[]byte類型轉化為io.Reader類型。

此外還可以給request的header中添加一些額外的資訊,比如下面例子中添加了請求的body的類型以及token的資訊。

reqest.Header.Set("Content-Type", "application/x-www-form-urlencoded")reqest.Header.Set("Authorization", "qwertyuiopasdfghjklzxcvbnm1234567890")

還有比如類比表單提交,可以把提交的類型設定為url.Values類型再進行Encode:

// use map as structvar clusterinfo = url.Values{}//var clusterinfo = map[string]string{}clusterinfo.Add("userName", user)clusterinfo.Add("password", pw)clusterinfo.Add("cloudName", clustername)clusterinfo.Add("masterIp", masterip)clusterinfo.Add("cacrt", string(caCrt))data := clusterinfo.Encode()url := "https://10.10.105.124:8443/user/checkAndUpdate"reqest, err := http.NewRequest("POST", url, strings.NewReader(data))

最常見的一種情況是發送一個json檔案過去,可以把Header的類型設定成為:

"Content-Type", "application/json; charset=utf-8"

其餘的部分按照先前同樣的方式進行設定發送提交就好。

request的類型的屬性還是比較多的,慢慢整理。

產生的response結果的處理

一般在client構建好之後,要採用client.Do(request)方法提交client請求,之後會返回一個*Response類型。response中的參數一般也比較多,我們需要的最多的通常是Body參數,一般通過body, _ := ioutil.ReadAll(resp.Body)會把body轉化為[]byte類型返回過來, 之後再進行其他的處理。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.