golang net/http包使用

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

http用戶端

import “net/http”
http包提供了HTTP用戶端和服務端的實現。

Get、Head、Post和PostForm函數發出HTTP/ HTTPS請求。

package mainimport (    "fmt"    "io/ioutil"    "net/http")func main() {    response, err := http.Get("http://www.baidu.com")    if err != nil {    // handle error    }    //程式在使用完回複後必須關閉回複的主體。    defer response.Body.Close()    body, _ := ioutil.ReadAll(response.Body)    fmt.Println(string(body))}
package mainimport (    "fmt"    "io/ioutil"    "net/http"    "bytes")func main() {    body := "{\"action\":20}"    res, err := http.Post("http://xxx.com", "application/json;charset=utf-8", bytes.NewBuffer([]byte(body)))    if err != nil {        fmt.Println("Fatal error ", err.Error())    }    defer res.Body.Close()    content, err := ioutil.ReadAll(res.Body)    if err != nil {        fmt.Println("Fatal error ", err.Error())    }    fmt.Println(string(content))}

還可以使用:
http.Client和http.NewRequest來類比請求

package mainimport (    "fmt"    "io/ioutil"    "net/http"    "net/url"    "strings")func main() {    v := url.Values{}    v.Set("username", "xxxx")    v.Set("password", "xxxx")    //利用指定的method,url以及可選的body返回一個新的請求.如果body參數實現了io.Closer介面,Request傳回值的Body 欄位會被設定為body,並會被Client類型的Do、Post和PostFOrm方法以及Transport.RoundTrip方法關閉。    body := ioutil.NopCloser(strings.NewReader(v.Encode())) //把form資料編下碼    client := &http.Client{}//用戶端,被Get,Head以及Post使用    reqest, err := http.NewRequest("POST", "http://xxx.com/logindo", body)    if err != nil {        fmt.Println("Fatal error ", err.Error())    }    //給一個key設定為響應的value.    reqest.Header.Set("Content-Type", "application/x-www-form-urlencoded;param=value") //必須設定該參數,POST參數才能正常提交    resp, err := client.Do(reqest)//發送請求    defer resp.Body.Close()//一定要關閉resp.Body    content, err := ioutil.ReadAll(resp.Body)    if err != nil {        fmt.Println("Fatal error ", err.Error())    }    fmt.Println(string(content))}

如何建立web服務端?

package mainimport (    "net/http")func SayHello(w http.ResponseWriter, req *http.Request) {    w.Write([]byte("Hello"))}func main() {    http.HandleFunc("/hello", SayHello)    http.ListenAndServe(":8001", nil)}

首先調用Http.HandleFunc
按順序做了幾件事:
* 調用了DefaultServerMux的HandleFunc
* 調用了DefaultServerMux的Handle
* 往DefaultServeMux的map[string]muxEntry中增加對應的handler和路由規則

其次調用http.ListenAndServe(“:8001”, nil)
按順序做了幾件事情:
* 執行個體化Server
* 調用Server的ListenAndServe()
* 調用net.Listen(“tcp”, addr)監聽連接埠
* 啟動一個for迴圈,在迴圈體中Accept請求
* 對每個請求執行個體化一個Conn,並且開啟一個goroutine為這個請求進行服務go c.serve()
* 讀取每個請求的內容w, err := c.readRequest()
* 判斷header是否為空白,如果沒有設定handler(這個例子就沒有設定handler),handler就設定為DefaultServeMux
* 調用handler的ServeHttp
* 在這個例子中,下面就進入到DefaultServerMux.ServeHttp
* 根據request選擇handler,並且進入到這個handler的ServeHTTP

   mux.handler(r).ServeHTTP(w, r)

* 選擇handler:

A 判斷是否有路由能滿足這個request(迴圈遍曆ServerMux的muxEntry)B 如果有路由滿足,調用這個路由handler的ServeHttpC 如果沒有路由滿足,調用NotFoundHandler的ServeHttp

著作權聲明:本文為博主原創文章,未經博主允許不得轉載。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.