79 lines
1.8 KiB
Go
79 lines
1.8 KiB
Go
|
package push
|
|||
|
|
|||
|
import (
|
|||
|
"bytes"
|
|||
|
"crypto/tls"
|
|||
|
"fmt"
|
|||
|
"io"
|
|||
|
"net/http"
|
|||
|
"time"
|
|||
|
)
|
|||
|
|
|||
|
// Get 请求 link:请求url
|
|||
|
func HttpGet(link string, header map[string]string) ([]byte, error) {
|
|||
|
client := &http.Client{Timeout: 20 * time.Second}
|
|||
|
//忽略https的证书
|
|||
|
client.Transport = &http.Transport{
|
|||
|
TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
|
|||
|
}
|
|||
|
|
|||
|
req, err := http.NewRequest("GET", link, nil)
|
|||
|
if err != nil {
|
|||
|
return nil, err
|
|||
|
}
|
|||
|
if header != nil {
|
|||
|
for k, v := range header {
|
|||
|
req.Header.Add(k, v)
|
|||
|
}
|
|||
|
}
|
|||
|
resp, err := client.Do(req)
|
|||
|
if err != nil {
|
|||
|
return nil, err
|
|||
|
}
|
|||
|
defer resp.Body.Close()
|
|||
|
|
|||
|
if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusForbidden || resp.StatusCode == http.StatusUnauthorized {
|
|||
|
return io.ReadAll(resp.Body)
|
|||
|
}
|
|||
|
|
|||
|
if resp.StatusCode != http.StatusOK {
|
|||
|
return nil, fmt.Errorf("%d:%s", resp.StatusCode, resp.Status)
|
|||
|
}
|
|||
|
return io.ReadAll(resp.Body)
|
|||
|
}
|
|||
|
|
|||
|
// PostJson 请求
|
|||
|
func HttpPostJson(link string, header map[string]string, json []byte) ([]byte, error) {
|
|||
|
client := &http.Client{Timeout: 20 * time.Second}
|
|||
|
//忽略https的证书
|
|||
|
client.Transport = &http.Transport{
|
|||
|
TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
|
|||
|
}
|
|||
|
|
|||
|
req, err := http.NewRequest("POST", link, bytes.NewBuffer(json))
|
|||
|
if err != nil {
|
|||
|
return nil, err
|
|||
|
}
|
|||
|
if header != nil {
|
|||
|
for k, v := range header {
|
|||
|
req.Header.Add(k, v)
|
|||
|
}
|
|||
|
}
|
|||
|
req.Header.Add("Content-Type", "application/json")
|
|||
|
|
|||
|
resp, err := client.Do(req)
|
|||
|
if err != nil {
|
|||
|
return nil, err
|
|||
|
}
|
|||
|
defer resp.Body.Close()
|
|||
|
|
|||
|
if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusForbidden || resp.StatusCode == http.StatusUnauthorized {
|
|||
|
return io.ReadAll(resp.Body)
|
|||
|
}
|
|||
|
|
|||
|
if resp.StatusCode != http.StatusOK {
|
|||
|
return nil, fmt.Errorf("%d:%s", resp.StatusCode, resp.Status)
|
|||
|
}
|
|||
|
return io.ReadAll(resp.Body)
|
|||
|
}
|