這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
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
著作權聲明:本文為博主原創文章,未經博主允許不得轉載。