http.go 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. package util
  2. import (
  3. "bytes"
  4. "crypto/tls"
  5. "encoding/json"
  6. "encoding/pem"
  7. "encoding/xml"
  8. "fmt"
  9. "golang.org/x/crypto/pkcs12"
  10. "io"
  11. "io/ioutil"
  12. "log"
  13. "mime/multipart"
  14. "net/http"
  15. "os"
  16. )
  17. //HTTPGet get 请求
  18. func HTTPGet(uri string) ([]byte, error) {
  19. response, err := http.Get(uri)
  20. if err != nil {
  21. return nil, err
  22. }
  23. defer response.Body.Close()
  24. if response.StatusCode != http.StatusOK {
  25. return nil, fmt.Errorf("http get error : uri=%v , statusCode=%v", uri, response.StatusCode)
  26. }
  27. return ioutil.ReadAll(response.Body)
  28. }
  29. //PostJSON post json 数据请求
  30. func PostJSON(uri string, obj interface{}) ([]byte, error) {
  31. jsonData, err := json.Marshal(obj)
  32. if err != nil {
  33. return nil, err
  34. }
  35. jsonData = bytes.Replace(jsonData, []byte("\\u003c"), []byte("<"), -1)
  36. jsonData = bytes.Replace(jsonData, []byte("\\u003e"), []byte(">"), -1)
  37. jsonData = bytes.Replace(jsonData, []byte("\\u0026"), []byte("&"), -1)
  38. body := bytes.NewBuffer(jsonData)
  39. response, err := http.Post(uri, "application/json;charset=utf-8", body)
  40. if err != nil {
  41. return nil, err
  42. }
  43. defer response.Body.Close()
  44. if response.StatusCode != http.StatusOK {
  45. return nil, fmt.Errorf("http get error : uri=%v , statusCode=%v", uri, response.StatusCode)
  46. }
  47. return ioutil.ReadAll(response.Body)
  48. }
  49. //PostFile 上传文件
  50. func PostFile(fieldname, filename, uri string) ([]byte, error) {
  51. fields := []MultipartFormField{
  52. {
  53. IsFile: true,
  54. Fieldname: fieldname,
  55. Filename: filename,
  56. },
  57. }
  58. return PostMultipartForm(fields, uri)
  59. }
  60. //MultipartFormField 保存文件或其他字段信息
  61. type MultipartFormField struct {
  62. IsFile bool
  63. Fieldname string
  64. Value []byte
  65. Filename string
  66. }
  67. //PostMultipartForm 上传文件或其他多个字段
  68. func PostMultipartForm(fields []MultipartFormField, uri string) (respBody []byte, err error) {
  69. bodyBuf := &bytes.Buffer{}
  70. bodyWriter := multipart.NewWriter(bodyBuf)
  71. for _, field := range fields {
  72. if field.IsFile {
  73. fileWriter, e := bodyWriter.CreateFormFile(field.Fieldname, field.Filename)
  74. if e != nil {
  75. err = fmt.Errorf("error writing to buffer , err=%v", e)
  76. return
  77. }
  78. fh, e := os.Open(field.Filename)
  79. if e != nil {
  80. err = fmt.Errorf("error opening file , err=%v", e)
  81. return
  82. }
  83. defer fh.Close()
  84. if _, err = io.Copy(fileWriter, fh); err != nil {
  85. return
  86. }
  87. } else {
  88. partWriter, e := bodyWriter.CreateFormField(field.Fieldname)
  89. if e != nil {
  90. err = e
  91. return
  92. }
  93. valueReader := bytes.NewReader(field.Value)
  94. if _, err = io.Copy(partWriter, valueReader); err != nil {
  95. return
  96. }
  97. }
  98. }
  99. contentType := bodyWriter.FormDataContentType()
  100. bodyWriter.Close()
  101. resp, e := http.Post(uri, contentType, bodyBuf)
  102. if e != nil {
  103. err = e
  104. return
  105. }
  106. defer resp.Body.Close()
  107. if resp.StatusCode != http.StatusOK {
  108. return nil, err
  109. }
  110. respBody, err = ioutil.ReadAll(resp.Body)
  111. return
  112. }
  113. //PostXML perform a HTTP/POST request with XML body
  114. func PostXML(uri string, obj interface{}) ([]byte, error) {
  115. xmlData, err := xml.Marshal(obj)
  116. if err != nil {
  117. return nil, err
  118. }
  119. body := bytes.NewBuffer(xmlData)
  120. response, err := http.Post(uri, "application/xml;charset=utf-8", body)
  121. if err != nil {
  122. return nil, err
  123. }
  124. defer response.Body.Close()
  125. if response.StatusCode != http.StatusOK {
  126. return nil, fmt.Errorf("http code error : uri=%v , statusCode=%v", uri, response.StatusCode)
  127. }
  128. return ioutil.ReadAll(response.Body)
  129. }
  130. //httpWithTLS CA证书
  131. func httpWithTLS(rootCa, key string) (*http.Client, error) {
  132. var client *http.Client
  133. certData, err := ioutil.ReadFile(rootCa)
  134. if err != nil {
  135. return nil, fmt.Errorf("unable to find cert path=%s, error=%v", rootCa, err)
  136. }
  137. cert := pkcs12ToPem(certData, key)
  138. config := &tls.Config{
  139. Certificates: []tls.Certificate{cert},
  140. }
  141. tr := &http.Transport{
  142. TLSClientConfig: config,
  143. DisableCompression: true,
  144. }
  145. client = &http.Client{Transport: tr}
  146. return client, nil
  147. }
  148. //pkcs12ToPem 将Pkcs12转成Pem
  149. func pkcs12ToPem(p12 []byte, password string) tls.Certificate {
  150. blocks, err := pkcs12.ToPEM(p12, password)
  151. defer func() {
  152. if x := recover(); x != nil {
  153. log.Print(x)
  154. }
  155. }()
  156. if err != nil {
  157. panic(err)
  158. }
  159. var pemData []byte
  160. for _, b := range blocks {
  161. pemData = append(pemData, pem.EncodeToMemory(b)...)
  162. }
  163. cert, err := tls.X509KeyPair(pemData, pemData)
  164. if err != nil {
  165. panic(err)
  166. }
  167. return cert
  168. }
  169. //PostXMLWithTLS:Post XML with TLS
  170. func PostXMLWithTLS(uri string, obj interface{}, ca, key string) ([]byte, error) {
  171. xmlData, err := xml.Marshal(obj)
  172. if err != nil {
  173. return nil, err
  174. }
  175. body := bytes.NewBuffer(xmlData)
  176. client, err := httpWithTLS(ca, key)
  177. if err != nil {
  178. return nil, err
  179. }
  180. response, err := client.Post(uri, "application/xml;charset=utf-8", body)
  181. if err != nil {
  182. return nil, err
  183. }
  184. defer response.Body.Close()
  185. if response.StatusCode != http.StatusOK {
  186. return nil, fmt.Errorf("http code error : uri=%v , statusCode=%v", uri, response.StatusCode)
  187. }
  188. return ioutil.ReadAll(response.Body)
  189. }