You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
http/client.go

212 lines
5.4 KiB
Go

/**
* @Author: Echo
* @Email: 1711788888@qq.com
* @Date: 2021/8/14 4:11 下午
* @Desc: TODO
*/
package http
import (
"context"
"crypto/tls"
"encoding/base64"
"net/http"
"net/http/cookiejar"
"time"
)
type Client struct {
http.Client
headers map[string]string
cookies map[string]string
ctx context.Context
baseUrl string
retryCount int
retryInterval time.Duration
middlewares []MiddlewareFunc
}
const (
defaultUserAgent = "DobyteHttpClient"
HeaderUserAgent = "User-Agent"
HeaderContentType = "Content-Type"
HeaderAuthorization = "Authorization"
HeaderCookie = "Cookie"
HeaderHost = "Host"
ContentTypeJson = "application/json"
ContentTypeXml = "application/xml"
ContentTypeFormData = "form-data"
ContentTypeFormUrlEncoded = "application/x-www-form-urlencoded"
)
func NewClient() *Client {
client := &Client{
Client: http.Client{
Transport: &http.Transport{
DisableKeepAlives: true,
TLSClientConfig: &tls.Config{
InsecureSkipVerify: true,
},
},
},
headers: make(map[string]string),
cookies: make(map[string]string),
middlewares: make([]MiddlewareFunc, 0),
}
client.headers[HeaderUserAgent] = defaultUserAgent
return client
}
// Set a header for the request.
func (c *Client) SetHeader(key, value string) *Client {
c.headers[key] = value
return c
}
// Set multiple headers for the request.
func (c *Client) SetHeaders(headers map[string]string) *Client {
for key, value := range headers {
c.headers[key] = value
}
return c
}
// Set a cookie for the request.
func (c *Client) SetCookie(key, value string) *Client {
c.cookies[key] = value
return c
}
// Set multiple cookies for the request.
func (c *Client) SetCookies(cookies map[string]string) *Client {
for key, value := range cookies {
c.cookies[key] = value
}
return c
}
// Set User-Agent for the request.
func (c *Client) SetUserAgent(agent string) *Client {
c.headers[HeaderUserAgent] = agent
return c
}
// Set Content-Type for the request.
func (c *Client) SetContentType(contentType string) *Client {
c.headers[HeaderContentType] = contentType
return c
}
// Enable browser mode for the request.
func (c *Client) SetBrowserMode() *Client {
jar, _ := cookiejar.New(nil)
c.Jar = jar
return c
}
//
func (c *Client) SetBaseUrl(baseUrl string) *Client {
c.baseUrl = baseUrl
return c
}
// SetBasicAuth set HTTP basic authentication information for the request.
func (c *Client) SetBasicAuth(username, password string) *Client {
c.headers[HeaderAuthorization] = "Basic " + base64.StdEncoding.EncodeToString([]byte(username+":"+password))
return c
}
// SetBearerToken set HTTP Bearer-Token authentication information for the request.
func (c *Client) SetBearerToken(token string) *Client {
c.headers[HeaderAuthorization] = "Bearer " + token
return c
}
// SetContext set context for the request.
func (c *Client) SetContext(ctx context.Context) *Client {
c.ctx = ctx
return c
}
// SetTimeOut sets the request timeout for the client.
func (c *Client) SetTimeout(timeout time.Duration) *Client {
c.Client.Timeout = timeout
return c
}
// SetRetry sets count and interval of retry for the request.
func (c *Client) SetRetry(retryCount int, retryInterval time.Duration) *Client {
c.retryCount = retryCount
c.retryInterval = retryInterval
return c
}
func (c *Client) SetKeepAlive(enable bool) {
//c.Transport.
}
// Use sets middleware for the request.
func (c *Client) Use(middlewares ...MiddlewareFunc) *Client {
c.middlewares = append(c.middlewares, middlewares...)
return c
}
// Download download a file from the network address to the local.
func (c *Client) Download(url, dir string, filename ...string) (string, error) {
return NewDownload(c).Download(url, dir, filename...)
}
// Request send an http request.
func (c *Client) Request(method, url string, data ...interface{}) (*Response, error) {
return NewRequest(c).request(method, url, data...)
}
// Get send an http request use get method.
func (c *Client) Get(url string, data ...interface{}) (*Response, error) {
return c.Request(MethodGet, url, data...)
}
// Post send an http request use post method.
func (c *Client) Post(url string, data ...interface{}) (*Response, error) {
return c.Request(MethodPost, url, data...)
}
// Put send an http request use put method.
func (c *Client) Put(url string, data ...interface{}) (*Response, error) {
return c.Request(MethodPut, url, data...)
}
// Patch send an http request use patch method.
func (c *Client) Patch(url string, data ...interface{}) (*Response, error) {
return c.Request(MethodPatch, url, data...)
}
// Delete send an http request use patch method.
func (c *Client) Delete(url string, data ...interface{}) (*Response, error) {
return c.Request(MethodDelete, url, data...)
}
// Head send an http request use head method.
func (c *Client) Head(url string, data ...interface{}) (*Response, error) {
return c.Request(MethodHead, url, data...)
}
// Options send an http request use options method.
func (c *Client) Options(url string, data ...interface{}) (*Response, error) {
return c.Request(MethodOptions, url, data...)
}
// Connect send an http request use connect method.
func (c *Client) Connect(url string, data ...interface{}) (*Response, error) {
return c.Request(MethodConnect, url, data...)
}
// Trace send an http request use trace method.
func (c *Client) Trace(url string, data ...interface{}) (*Response, error) {
return c.Request(MethodTrace, url, data...)
}