您好,登錄后才能下訂單哦!
方式一 使用http.Newrequest
先生成http.client -> 再生成 http.request -> 之后提交請求:client.Do(request) -> 處理返回結果,每一步的過程都可以設置一些具體的參數,下面是一個最樸素最基本的例子:
//question ???將stdout重定向為response信息??? package main import ( "fmt" "io" "net/http" "os" ) func main() { //生成client 參數為默認 client := &http.Client{} //生成要訪問的url url := "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.StatusCode fmt.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的時候,什么信息都不添加,就會使用默認的值。具體的信息包括:
第一個參數是一個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 struct var 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類型返回過來, 之后再進行其他的處理。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。