-
基礎概念
- 請求:客戶端訪問服務端
- 響應:服務端對客戶端的應答
- 示例圖
-
帶有特殊請求頭和cookie值得客戶端請求方式
- 使用:http.NewRequest,Do()組合。並且在創建請求的時候,帶上cookie值和其他請求頭
- 參考代碼
package main import ( "bytes" "encoding/json" "fmt" "io/ioutil" "net/http" "time" ) var cookies []*http.Cookie var url = "XXXXX" // login func Login() { req := ReqProto{} data := make(map[string]string) data["test"] = "11" req.Data = data logginClient := http.Client{} logginJsonStr, err := json.Marshal(&req) if err != nil { err := fmt.Errorf("登錄發起post請求時,json.Mashal錯誤:%v", err) fmt.Println(err) return } logginRequest, err := http.NewRequest("POST", url, bytes.NewBuffer(logginJsonStr)) if err != nil { err := fmt.Errorf("登錄發起post請求時,http.NewRequest錯誤:%v", err) fmt.Println(err) return } logginRequest.Header.Set("Content-Type", "application/json") logginRequest.Header.Set("Content-Type", "application/x-www-form-urlencoded") loginResponse, err := logginClient.Do(logginRequest) if err != nil { err := fmt.Errorf("登錄發起post請求時,client.Do錯誤:%v", err) fmt.Println(err) return } fmt.Println(loginResponse) if loginResponse.StatusCode != 200 { err := fmt.Errorf("登錄發起post請求時,response.StatusCode:%v", loginResponse.StatusCode) fmt.Println(err) return } else { data, err := ioutil.ReadAll(loginResponse.Body) if err != nil { fmt.Println(err) return } var dataJSON interface{} json.Unmarshal(data, &dataJSON) fmt.Println(dataJSON) } fmt.Println("登錄成功") cookies = loginResponse.Cookies() } // StaticData func StaticData() { client := http.Client{} req, err := http.NewRequest("GET",url, nil) if err != nil { fmt.Println(err) return } for i := 0; i < len(cookies); i++ { req.AddCookie(cookies[i]) } resp, err := client.Do(req) if err != nil { fmt.Println(err) return } defer resp.Body.Close() data, err := ioutil.ReadAll(resp.Body) if err != nil { fmt.Println(err) return } fmt.Println(string(data)) } func main() { Login() StaticData() }