From 81c320d96a4abcdc276c52a5c8a5a5baa8b36532 Mon Sep 17 00:00:00 2001
From: liuxiaolong <liuxiaolong@aiotlink.com>
Date: 星期五, 18 十二月 2020 14:23:57 +0800
Subject: [PATCH] 添加两个接口

---
 httpClient.go |   39 ++++++++++++++++++++++++++++++---------
 1 files changed, 30 insertions(+), 9 deletions(-)

diff --git a/httpClient.go b/httpClient.go
index e9564c7..2cdca21 100644
--- a/httpClient.go
+++ b/httpClient.go
@@ -6,6 +6,8 @@
 	"io/ioutil"
 	"log"
 	"net/http"
+	"strings"
+	"github.com/ajg/form"
 )
 
 type HttpClient struct{}
@@ -25,7 +27,12 @@
 		}
 		request.URL.RawQuery = query.Encode()
 	}
-	//add headers
+	// add headers
+	if headers != nil {
+		for key, val := range headers {
+			request.Header.Add(key, val)
+		}
+	}
 	client := &http.Client{}
 	resp, err := client.Do(request)
 	if err != nil {
@@ -42,18 +49,32 @@
 //鍙戣捣POST璇锋眰
 func (httpApi HttpClient) DoPostRequest(url string, contentType string, body map[string]interface{}, params map[string]string, headers map[string]string) ([]byte, error) {
 	var resultBytes []byte
-	var bodyJson []byte
-	if body != nil {
-		var err error
-		bodyJson, err = json.Marshal(body)
+	var request *http.Request
+	var err error
+	if contentType == CONTENT_TYPE_FORM || contentType == CONTENT_TYPE_MULFORM {
+		formData,err := form.EncodeToString(body)
+		if err !=nil {
+			return resultBytes,err
+		}
+		request, err = http.NewRequest("POST",url,strings.NewReader(formData))
+		if err !=nil {
+			return resultBytes,err
+		}
+	} else {
+		var bodyJson []byte
+		if body != nil {
+			var err error
+			bodyJson, err = json.Marshal(body)
+			if err != nil {
+				return resultBytes, err
+			}
+		}
+		request, err = http.NewRequest("POST", url, bytes.NewBuffer(bodyJson))
 		if err != nil {
 			return resultBytes, err
 		}
 	}
-	request, err := http.NewRequest("POST", url, bytes.NewBuffer(bodyJson))
-	if err != nil {
-		return resultBytes, err
-	}
+
 	request.Header.Set("Content-type", contentType)
 	//add params
 	q := request.URL.Query()

--
Gitblit v1.8.0