http.go 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. package util
  2. import (
  3. "bytes"
  4. "crypto/tls"
  5. "encoding/json"
  6. "fmt"
  7. "io"
  8. "io/ioutil"
  9. "mime/multipart"
  10. "net"
  11. "net/http"
  12. "os"
  13. "time"
  14. )
  15. //HTTPGet get 请求
  16. func HTTPGet(uri string) ([]byte, error) {
  17. response, err := http.Get(uri)
  18. if err != nil {
  19. return nil, err
  20. }
  21. defer response.Body.Close()
  22. if response.StatusCode != http.StatusOK {
  23. return nil, fmt.Errorf("http get error : uri=%v , statusCode=%v", uri, response.StatusCode)
  24. }
  25. return ioutil.ReadAll(response.Body)
  26. }
  27. //PostJSON post json 数据请求
  28. func PostJSON(uri string, obj interface{}) ([]byte, error) {
  29. jsonData, err := json.Marshal(obj)
  30. if err != nil {
  31. return nil, err
  32. }
  33. jsonData = bytes.Replace(jsonData, []byte("\\u003c"), []byte("<"), -1)
  34. jsonData = bytes.Replace(jsonData, []byte("\\u003e"), []byte(">"), -1)
  35. jsonData = bytes.Replace(jsonData, []byte("\\u0026"), []byte("&"), -1)
  36. body := bytes.NewBuffer(jsonData)
  37. response, err := http.Post(uri, "application/json;charset=utf-8", body)
  38. if err != nil {
  39. return nil, err
  40. }
  41. defer response.Body.Close()
  42. if response.StatusCode != http.StatusOK {
  43. return nil, fmt.Errorf("http get error : uri=%v , statusCode=%v", uri, response.StatusCode)
  44. }
  45. return ioutil.ReadAll(response.Body)
  46. }
  47. //PostFile 上传文件
  48. func PostFile(fieldname, filename, uri string) ([]byte, error) {
  49. fields := []MultipartFormField{
  50. {
  51. IsFile: true,
  52. Fieldname: fieldname,
  53. Filename: filename,
  54. },
  55. }
  56. return PostMultipartForm(fields, uri)
  57. }
  58. //MultipartFormField 保存文件或其他字段信息
  59. type MultipartFormField struct {
  60. IsFile bool
  61. Fieldname string
  62. Value []byte
  63. Filename string
  64. }
  65. //PostMultipartForm 上传文件或其他多个字段
  66. func PostMultipartForm(fields []MultipartFormField, uri string) (respBody []byte, err error) {
  67. bodyBuf := &bytes.Buffer{}
  68. bodyWriter := multipart.NewWriter(bodyBuf)
  69. for _, field := range fields {
  70. if field.IsFile {
  71. fileWriter, e := bodyWriter.CreateFormFile(field.Fieldname, field.Filename)
  72. if e != nil {
  73. err = fmt.Errorf("error writing to buffer , err=%v", e)
  74. return
  75. }
  76. fh, e := os.Open(field.Filename)
  77. if e != nil {
  78. err = fmt.Errorf("error opening file , err=%v", e)
  79. return
  80. }
  81. defer fh.Close()
  82. if _, err = io.Copy(fileWriter, fh); err != nil {
  83. return
  84. }
  85. } else {
  86. partWriter, e := bodyWriter.CreateFormField(field.Fieldname)
  87. if e != nil {
  88. err = e
  89. return
  90. }
  91. valueReader := bytes.NewReader(field.Value)
  92. if _, err = io.Copy(partWriter, valueReader); err != nil {
  93. return
  94. }
  95. }
  96. }
  97. contentType := bodyWriter.FormDataContentType()
  98. bodyWriter.Close()
  99. resp, e := http.Post(uri, contentType, bodyBuf)
  100. if e != nil {
  101. err = e
  102. return
  103. }
  104. defer resp.Body.Close()
  105. if resp.StatusCode != http.StatusOK {
  106. return nil, err
  107. }
  108. respBody, err = ioutil.ReadAll(resp.Body)
  109. return
  110. }
  111. //NewTLSHttpClientFromContent 创建支持双向证书认证的 http.Client, certContent keyContent为证书或key的内容
  112. func NewTLSHttpClientFromContent(certContent, keyContent string) (httpClient *http.Client, err error) {
  113. cert, err := tls.X509KeyPair([]byte(certContent), []byte(keyContent))
  114. if err != nil {
  115. return
  116. }
  117. tlsConfig := &tls.Config{
  118. Certificates: []tls.Certificate{cert},
  119. }
  120. httpClient = &http.Client{
  121. Transport: &http.Transport{
  122. Proxy: http.ProxyFromEnvironment,
  123. Dial: (&net.Dialer{
  124. Timeout: 30 * time.Second,
  125. KeepAlive: 30 * time.Second,
  126. }).Dial,
  127. TLSHandshakeTimeout: 10 * time.Second,
  128. TLSClientConfig: tlsConfig,
  129. },
  130. Timeout: 60 * time.Second,
  131. }
  132. return
  133. }
  134. // NewTLSHttpClient 创建支持双向证书认证的 http.Client
  135. func NewTLSHttpClient(certFile, keyFile string) (httpClient *http.Client, err error) {
  136. cert, err := tls.LoadX509KeyPair(certFile, keyFile)
  137. if err != nil {
  138. return
  139. }
  140. tlsConfig := &tls.Config{
  141. Certificates: []tls.Certificate{cert},
  142. }
  143. httpClient = &http.Client{
  144. Transport: &http.Transport{
  145. Proxy: http.ProxyFromEnvironment,
  146. Dial: (&net.Dialer{
  147. Timeout: 30 * time.Second,
  148. KeepAlive: 30 * time.Second,
  149. }).Dial,
  150. TLSHandshakeTimeout: 10 * time.Second,
  151. TLSClientConfig: tlsConfig,
  152. },
  153. Timeout: 60 * time.Second,
  154. }
  155. return
  156. }