http.go 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  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(url 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(url, "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", url, 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. fmt.Print("can not init cert...")
  116. return nil, err
  117. }
  118. tlsConfig := &tls.Config{
  119. Certificates: []tls.Certificate{cert},
  120. }
  121. httpClient = &http.Client{
  122. Transport: &http.Transport{
  123. Proxy: http.ProxyFromEnvironment,
  124. Dial: (&net.Dialer{
  125. Timeout: 30 * time.Second,
  126. KeepAlive: 30 * time.Second,
  127. }).Dial,
  128. TLSHandshakeTimeout: 10 * time.Second,
  129. TLSClientConfig: tlsConfig,
  130. },
  131. Timeout: 60 * time.Second,
  132. }
  133. return
  134. }
  135. // NewTLSHttpClient 创建支持双向证书认证的 http.Client
  136. func NewTLSHttpClient(certFile, keyFile string) (httpClient *http.Client, err error) {
  137. cert, err := tls.LoadX509KeyPair(certFile, keyFile)
  138. if err != nil {
  139. fmt.Print("can not init cert...")
  140. return nil, err
  141. }
  142. tlsConfig := &tls.Config{
  143. Certificates: []tls.Certificate{cert},
  144. }
  145. httpClient = &http.Client{
  146. Transport: &http.Transport{
  147. Proxy: http.ProxyFromEnvironment,
  148. Dial: (&net.Dialer{
  149. Timeout: 30 * time.Second,
  150. KeepAlive: 30 * time.Second,
  151. }).Dial,
  152. TLSHandshakeTimeout: 10 * time.Second,
  153. TLSClientConfig: tlsConfig,
  154. },
  155. Timeout: 60 * time.Second,
  156. }
  157. return
  158. }