# http客戶端
import “net/http”
http包提供了HTTP客戶端和服務端的實現。
Get、Head、Post和PostForm函數發出HTTP/ HTTPS請求。
~~~
package main
import (
"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 main
import (
"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 main
import (
"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 main
import (
"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的ServeHttp
C 如果沒有路由滿足,調用NotFoundHandler的ServeHttp
~~~
- 前言
- golang學習(一)之安裝
- Go語言學習二:Go基礎(變量、常量、數值類型、字符串、錯誤類型)
- Go語言學習三:Go基礎(iota,array,slice,map,make,new)
- Go語言學習四:struct類型
- Ubuntu 14.04/CentOS 6.5中安裝GO LANG(GO語言)
- Mac OS 安裝golang
- Mac install Thrift
- Thrift RPC 使用指南實戰(附golang&PHP代碼)
- golang net/http包使用
- 冒泡排序Bubble sort-golang
- 快速排序Quick sort - golang
- Go語言學習:Channel是什么?
- Golang的select/非緩沖的Channel實例詳解
- Golang time包的定時器/斷續器
- Golang同步:鎖的使用案例詳解
- Golang同步:條件變量和鎖組合使用
- Golang同步:原子操作使用
- Golang之bytes.buffer
- Golang之字符串格式化
- Golang之反射reflect包
- Go語言配置文件解析器,類似于Windows下的INI文件.