Golang提供了官方的http包,对于http操作非常的方便和简洁。
但是不同于PHP,使用Golang的包来做http操作,还是没有那么”直接“,需要实例化一下这个,实例化一下那个,有点像Java
,因此,为了以后书写方便,就把基本的请求写在此。下次用的时候,直接copy就好了。
get 请求
get请求有好几种方式
直接使用net/http
包内的函数请求
import "net/http"
...
resp, err := ("")
利用结构体来请求
import "net/http"
...
clt := {}
resp, err := ("")
最本质的请求方式
如果稍微看一下源码,就会发现以上两种方式都是用了一下这种最本质的请求方式,使用函数
req, err := ("GET", "", nil)
//然后 结构体的 Do 方法
//可以换为另外一个
resp, err := (req)
Go的get请求面上有好几种请求方式,实则只有一种:
1、使用函数获得
request
实体
2、利用结构体的
Do
方法,将request
实体传入Do
方法中。
post请求
和get请求类似,post请求也有多种方法,但本质还是使用了函数和
的
Do
方法。
使用net/http
包带的post方法
import (
"net/http"
"net/url"
)
...
data := {"start":{"0"}, "offset":{"xxxx"}}
body := (())
resp, err := ("xxxxxxx", "application/x-www-form-urlencoded", body)
或者还可以
import (
"net/http"
"net/url"
)
...
var r
()
("xxx", "xxx")
body := (())
("xxxx", "application/x-www-form-urlencoded", body)
要是还是觉得复杂,还可以:
import (
"net/http"
"net/url"
)
...
data := {"start":{"0"}, "offset":{"xxxx"}}
("xxxx", data)
使用实例化的http client的post方法
其实本质上直接使用包的函数和实例化的http client是一样的,包的函数底层也仅仅是实例化了一个DefaultClient
,然后调用的DefaultClient
的方法。下面给出使用实例化的http client的post方法:
import (
"net/http"
"net/url"
)
...
data := {"start":{"0"}, "offset":{"xxxx"}}
body := (())
clt := {}
resp, err := ("xxxxxxx", "application/x-www-form-urlencoded", body)
还有
import (
"net/http"
"net/url"
)
...
var r
()
("xxx", "xxx")
body := (())
clt := {}
("xxxx", "application/x-www-form-urlencoded", body)
简单的,但仅限于form表单
import (
"net/http"
"net/url"
)
...
data := {"start":{"0"}, "offset":{"xxxx"}}
clt := {}
("xxxx", data)
使用net/http
包的NewRequest
函数
其实不管是get方法也好,post方法也好,所有的get、post的的http 请求形式,最终都是会调用net/http
包的NewRequest
函数,多种多样的请求形式,也仅仅是封装的不同而已。
import (
"net/http"
"net/url"
)
...
data := {"start":{"0"}, "offset":{"xxxx"}}
body := (())
req, err := ("POST", "xxxxx", body)
("Content-Type", "application/x-www-form-urlencoded")
clt := {}
(req)
添加request header
net/http
包没有封装直接使用请求带header的get或者post方法,所以,要想请求中带header,只能使用NewRequest
方法。
import (
"net/http"
)
...
req, err := ("POST", "xxxxx", body)
//此处还可以写("User-Agent", "myClient")
("User-Agent", "myClient")
clt := {}
(req)
有一点需要注意:在添加header操作的时候,和
都可以,但是在修改操作的时候,只能使用
。
这俩方法是有区别的,Golang底层Header的实现是一个map[string][]string
,方法如果原来Header中没有值,那么是没问题的,如果又值,会将原来的值替换掉。而
的话,是在原来值的基础上,再
append
一个值,例如,原来header的值是“s”,我后一个”a”的话,变成了
[s a]
。但是,获取header值的方法确只取第一个,所以,如果原来有值,重新
一个新值的话,
得到的值不变。
打印response响应
Golang打印response没有PHP那么爽,哎,编译型语言就是麻烦。
import (
"net/http"
"net/url"
"io/ioutil"
)
...
content, err := ()
respBody := string(content)
使用cookie
Golang提供了cookie的包net/http/cookiejar
...
url, err := ("/")
jar, err := (nil)
(url, cookies)//这里的cookies是[]*
wukongClt := {Transport:nil, Jar:jar}
("xxxxx")
文中的cookies
类型是[] *
可以自己实例化,有时候也可以从response
中直接使用()
直接拿到。
Golang的cookie是和联系在一起的,作为
的一个属性存在。因此,要想在Golang中使用cookie,就必须想办法构造
使用代理
在Golang中使用http proxy,也必须构造自己的,需要将
结构体的一个属性
Transport
自己实例化好。
当使用环境变量$http_proxy或$HTTP_PROXY作为代理时
//从环境变量$http_proxy或$HTTP_PROXY中获取HTTP代理地址
func GetTransportFromEnvironment() (transport *) {
transport = &{Proxy : }
return
}
当使用自己搭建http代理时
参数proxy_addr
即代理服务器IP端口号,例如:”:6000“,注意,必须加上"http"
func GetTransportFieldURL(proxy_addr *string) (transport *) {
url_i := {}
url_proxy, error := url_i.Parse(*proxy_addr)
if error != nil{
(())
}
transport = &{Proxy : (url_proxy)}
return
}
使用的时候,首先调用函数,拿到对应的transport
,即使用GetTransportFieldURL
或者GetTransportFieldURL
函数,然后构建自定义的 :
ProxyUrl := ":6000"
transport := GetTransportFieldURL(&ProxyUrl)
clt := {Transport:transport}
("")