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) }