請求地址
var (
requestGetURLNoParams string = "http://httpbin.org/get"
requestGetURL string = "http://httpbin.org/get?a=ab=bc=ccc"
imageURL string = "http://httpbin.org/image"
)
普通get請求
// 基本get請求
func basicGet() {
resp, err := http.Get(requestGetURLNoParams)
if err != nil {
log.Println("err")
}
defer resp.Body.Close()
b, err := ioutil.ReadAll(resp.Body)
if err != nil {
log.Println("err")
}
fmt.Println(string(b))
}
請求參數放到url.Values{}
// get請求參數放到 "net/url"
func basicGetURLParams() {
params := url.Values{}
parseURL, err := url.Parse(requestGetURLNoParams)
if err != nil {
log.Println("err")
}
params.Set("aaa", "aaa")
params.Set("age", "23")
//如果參數中有中文參數,這個方法會進行URLEncode
parseURL.RawQuery = params.Encode()
urlPathWithParams := parseURL.String()
resp, err := http.Get(urlPathWithParams)
if err != nil {
log.Println("err")
}
defer resp.Body.Close()
b, err := ioutil.ReadAll(resp.Body)
if err != nil {
log.Println("err")
}
fmt.Println(string(b))
}
自定義請求(添加頭、cookie)
// 可以設置請求頭 添加cookie
func basicGetHeader() {
client := http.Client{}
req, err := http.NewRequest(http.MethodGet, requestGetURLNoParams, nil)
if err != nil {
log.Println("err")
}
// 添加請求頭
req.Header.Add("Content-type", "application/json;charset=utf-8")
req.Header.Add("header", "header😂😂")
// 添加cookie
cookie1 := http.Cookie{
Name: "aaa",
Value: "aaa-value",
}
req.AddCookie(cookie1)
// 發(fā)送請求
resp, err := client.Do(req)
if err != nil {
log.Println("err")
}
defer resp.Body.Close()
b, err := ioutil.ReadAll(resp.Body)
if err != nil {
log.Println("err")
}
fmt.Println(string(b))
}
接收文件–ioutil.WriteFile
// ioutil.ReadAll(resp.Body) 先將所有的響應讀出來放到內存中。如果文件太大,那么就會消耗很多內存
func basicGetDownloadFile() {
client := http.Client{}
req, err := http.NewRequest(http.MethodGet, imageURL, nil) // strings.NewReader(data)
if err != nil {
log.Println("err")
}
resp, err := client.Do(req)
if err != nil {
log.Println("err")
}
defer resp.Body.Close()
b, err := ioutil.ReadAll(resp.Body)
if err != nil {
log.Println("err")
}
ioutil.WriteFile("./images/img.jpg", b, 0644)
}
接收文件–io.Copy
// io.Copy() 省去了先把內容讀取到內存,然后將內存中的內容寫到文件
func basicGetDownloadFileIoCopy() {
client := http.Client{}
req, err := http.NewRequest(http.MethodGet, imageURL, nil)
if err != nil {
log.Println("err")
}
resp, err := client.Do(req)
if err != nil {
log.Println("err")
}
defer resp.Body.Close()
// 創(chuàng)建一個文件用于保存
dest, err := os.Create("./images/img.jpg")
if err != nil {
log.Println("err")
}
defer dest.Close()
// 然后將響應流和文件流對接起來
_, err = io.Copy(dest, resp.Body)
if err != nil {
log.Println("err")
}
}
補充:golang(go語言)消息傳遞(管道)方法實現(xiàn)發(fā)送多個get請求
1.需求說明
我用django rest framework寫了一個簡單的用戶增刪改查小案例,然后我想使用golang實現(xiàn)一個多并發(fā)請求,看看我的小項目能承受多少請求!初學go代碼不正確,請多多指點。
2.代碼實現(xiàn)
//基本的GET請求
package main
import (
"fmt"
"io/ioutil"
"net/http"
"time"
)
// HTTP get請求
func httpget(ch chan int){
resp, err := http.Get("http://localhost:8000/rest/api/user")
if err != nil {
fmt.Println(err)
return
}
defer resp.Body.Close()
body, err := ioutil.ReadAll(resp.Body)
fmt.Println(string(body))
fmt.Println(resp.StatusCode)
if resp.StatusCode == 200 {
fmt.Println("ok")
}
ch - 1
}
// 主方法
func main() {
start := time.Now()
// 注意設置緩沖區(qū)大小要和開啟協(xié)程的個人相等
chs := make([]chan int, 2000)
for i := 0; i 2000; i++ {
chs[i] = make(chan int)
go httpget(chs[i])
}
for _, ch := range chs {
- ch
}
end := time.Now()
consume := end.Sub(start).Seconds()
fmt.Println("程序執(zhí)行耗時(s):", consume)
}
3.結果
當我把開了10000個協(xié)程時候django后臺數據庫就崩了哈哈應該連接數過大導致的,所以我就試了2000個感覺有點并發(fā)的意思哈哈!左側是返回的json結果 右側是django的后臺!

4.總結
我們通過go語言的管道channel來實現(xiàn)并發(fā)請求,能夠解決何避免傳統(tǒng)共享內存實現(xiàn)并發(fā)的很多問題而且效率會高于共享內存的方法。
您可能感興趣的文章:- golang gopm get -g -v 無法獲取第三方庫的解決方案
- golang語言http協(xié)議get拼接參數操作
- Golang發(fā)送http GET請求的示例代碼
- Golang執(zhí)行go get私有庫提示"410 Gone" 的問題及解決辦法
- golang使用http client發(fā)起get和post請求示例
- 完美解決golang go get私有倉庫的問題