Documentation ¶
Overview ¶
Powerful and easy to use http client
Powerful and easy to use http client
Index ¶
- Constants
- Variables
- func IsRedirectError(err error) bool
- func IsTimeoutError(err error) bool
- func Option(o map[string]interface{}) map[int]interface{}
- type Error
- type HttpClient
- func (this *HttpClient) Begin() *HttpClient
- func (this *HttpClient) CookieValue(url_ string, key string) string
- func (this *HttpClient) CookieValues(url_ string) map[string]string
- func (this *HttpClient) Cookies(url_ string) []*http.Cookie
- func (this *HttpClient) Defaults(defaults Map) *HttpClient
- func (this *HttpClient) Delete(url string, params map[string]string) (*Response, error)
- func (this *HttpClient) Do(method string, url string, headers map[string]string, body io.Reader) (*Response, error)
- func (this *HttpClient) Get(url string, params map[string]string) (*Response, error)
- func (this *HttpClient) Head(url string, params map[string]string) (*Response, error)
- func (this *HttpClient) Post(url string, params map[string]string) (*Response, error)
- func (this *HttpClient) PostMultipart(url string, params map[string]string) (*Response, error)
- func (this *HttpClient) WithCookie(cookies ...*http.Cookie) *HttpClient
- func (this *HttpClient) WithHeader(k string, v string) *HttpClient
- func (this *HttpClient) WithHeaders(m map[string]string) *HttpClient
- func (this *HttpClient) WithOption(k int, v interface{}) *HttpClient
- func (this *HttpClient) WithOptions(m Map) *HttpClient
- type Map
- type Response
Constants ¶
const ( ERR_DEFAULT ERR_TIMEOUT ERR_REDIRECT_POLICY )
Package errors
const ( VERSION = "0.5.1" USERAGENT = "go-httpclient v" + VERSION PROXY_HTTP = 0 PROXY_SOCKS4 = 4 PROXY_SOCKS5 = 5 PROXY_SOCKS4A = 6 // CURL like OPT OPT_AUTOREFERER = 58 OPT_FOLLOWLOCATION = 52 OPT_CONNECTTIMEOUT = 78 OPT_CONNECTTIMEOUT_MS = 156 OPT_MAXREDIRS = 68 OPT_PROXYTYPE = 101 OPT_TIMEOUT = 13 OPT_TIMEOUT_MS = 155 OPT_COOKIEJAR = 10082 OPT_INTERFACE = 10062 OPT_PROXY = 10004 OPT_REFERER = 10016 OPT_USERAGENT = 10018 // Other OPT OPT_REDIRECT_POLICY = 100000 OPT_PROXY_FUNC = 100001 OPT_DEBUG = 100002 )
Constants definations CURL options, see https://github.com/bagder/curl/blob/169fedbdce93ecf14befb6e0e1ce6a2d480252a3/packages/OS400/curl.inc.in
Variables ¶
var Begin func() *HttpClient
var CONST = map[string]int{
"OPT_AUTOREFERER": 58,
"OPT_FOLLOWLOCATION": 52,
"OPT_CONNECTTIMEOUT": 78,
"OPT_CONNECTTIMEOUT_MS": 156,
"OPT_MAXREDIRS": 68,
"OPT_PROXYTYPE": 101,
"OPT_TIMEOUT": 13,
"OPT_TIMEOUT_MS": 155,
"OPT_COOKIEJAR": 10082,
"OPT_INTERFACE": 10062,
"OPT_PROXY": 10004,
"OPT_REFERER": 10016,
"OPT_USERAGENT": 10018,
"OPT_REDIRECT_POLICY": 100000,
"OPT_PROXY_FUNC": 100001,
"OPT_DEBUG": 100002,
}
String map of options
var CookieValue func(string, string) string
var CookieValues func(string) map[string]string
var Cookies func(string) []*http.Cookie
var Defaults func(Map) *HttpClient
var WithCookie func(...*http.Cookie) *HttpClient
var WithHeader func(string, string) *HttpClient
var WithHeaders func(map[string]string) *HttpClient
var WithOption func(int, interface{}) *HttpClient
var WithOptions func(Map) *HttpClient
Functions ¶
Types ¶
type HttpClient ¶
type HttpClient struct { // Default options of this client. Options map[int]interface{} // Default headers of this client. Headers map[string]string // contains filtered or unexported fields }
Powerful and easy to use HTTP client.
func (*HttpClient) Begin ¶ added in v0.3.0
func (this *HttpClient) Begin() *HttpClient
Begin marks the begining of a request, it's necessary for concurrent requests.
func (*HttpClient) CookieValue ¶ added in v0.3.2
func (this *HttpClient) CookieValue(url_ string, key string) string
Get cookie value of a specified cookie name.
func (*HttpClient) CookieValues ¶ added in v0.3.2
func (this *HttpClient) CookieValues(url_ string) map[string]string
Get cookie values(k-v map) of the client jar.
func (*HttpClient) Cookies ¶ added in v0.3.2
func (this *HttpClient) Cookies(url_ string) []*http.Cookie
Get cookies of the client jar.
func (*HttpClient) Defaults ¶ added in v0.5.0
func (this *HttpClient) Defaults(defaults Map) *HttpClient
Set default options and headers.
func (*HttpClient) Do ¶ added in v0.2.1
func (this *HttpClient) Do(method string, url string, headers map[string]string, body io.Reader) (*Response, error)
Start a request, and get the response.
Usually we just need the Get and Post method.
func (*HttpClient) Post ¶
The POST request
With multipart set to true, the request will be encoded as "multipart/form-data".
If any of the params key starts with "@", it is considered as a form file (similar to CURL but different).
func (*HttpClient) PostMultipart ¶ added in v0.2.1
Post with the request encoded as "multipart/form-data".
func (*HttpClient) WithCookie ¶ added in v0.3.0
func (this *HttpClient) WithCookie(cookies ...*http.Cookie) *HttpClient
Specify cookies of the current request.
func (*HttpClient) WithHeader ¶ added in v0.2.1
func (this *HttpClient) WithHeader(k string, v string) *HttpClient
Temporarily specify a header of the current request.
func (*HttpClient) WithHeaders ¶ added in v0.2.1
func (this *HttpClient) WithHeaders(m map[string]string) *HttpClient
Temporarily specify multiple headers of the current request.
func (*HttpClient) WithOption ¶ added in v0.2.1
func (this *HttpClient) WithOption(k int, v interface{}) *HttpClient
Temporarily specify an option of the current request.
func (*HttpClient) WithOptions ¶ added in v0.2.1
func (this *HttpClient) WithOptions(m Map) *HttpClient
Temporarily specify multiple options of the current request.
type Map ¶ added in v0.4.0
type Map map[interface{}]interface{}
Map is a mixed structure with options and headers