From c007f0ca1785db093d48f4846cda82fe8e955765 Mon Sep 17 00:00:00 2001
From: kimi <kimi42345@gmail.com>
Date: 星期三, 27 五月 2020 09:59:29 +0800
Subject: [PATCH] merage

---
 src/main/java/com/highdatas/mdm/util/HttpUtils.java |  125 ++++++++++++++++++++++++++++++++++++-----
 1 files changed, 108 insertions(+), 17 deletions(-)

diff --git a/src/main/java/com/highdatas/mdm/util/HttpUtils.java b/src/main/java/com/highdatas/mdm/util/HttpUtils.java
index 632b2f2..072574e 100644
--- a/src/main/java/com/highdatas/mdm/util/HttpUtils.java
+++ b/src/main/java/com/highdatas/mdm/util/HttpUtils.java
@@ -1,11 +1,23 @@
 package com.highdatas.mdm.util;
 
-import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.beans.factory.annotation.Value;
+
+import lombok.extern.slf4j.Slf4j;
 import org.springframework.http.*;
 import org.springframework.http.client.SimpleClientHttpRequestFactory;
+import org.springframework.http.converter.StringHttpMessageConverter;
+import org.springframework.stereotype.Component;
+import org.springframework.util.LinkedMultiValueMap;
 import org.springframework.util.MultiValueMap;
+import org.springframework.util.StringUtils;
 import org.springframework.web.client.RestTemplate;
+
+import java.nio.charset.StandardCharsets;
+import java.text.MessageFormat;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.stream.Collectors;
 
 /**
  * @author kimi
@@ -13,23 +25,102 @@
  * @date 2019-12-13 13:35
  */
 
-
+@Component
+@Slf4j
 public class HttpUtils {
-
-
-    public static String HttpRestClient(String url, HttpMethod method, MultiValueMap<String, String> params) {
-        SimpleClientHttpRequestFactory requestFactory = new SimpleClientHttpRequestFactory();
-        requestFactory.setConnectTimeout(15*1000);
-        requestFactory.setReadTimeout(15*1000);
-        RestTemplate client = new RestTemplate(requestFactory);
-        HttpHeaders headers = new HttpHeaders();
-
-        headers.setContentType(MediaType.APPLICATION_FORM_URLENCODED);
-        HttpEntity<MultiValueMap<String, String>> requestEntity = new HttpEntity<MultiValueMap<String, String>>(params, headers);
-        //  鎵цHTTP璇锋眰
-        ResponseEntity<String> response = client.exchange(url, method, requestEntity, String.class);
-        return response.getBody();
+    public static String HttpRestClient(String url, HttpMethod method, Map<String, String> formParams) {
+        return HttpRestClient(url,method,formParams, null, null);
     }
 
+    public static String HttpRestClient(String url, HttpMethod method, Map<String, String> formParams, String getParams) {
+        return HttpRestClient(url,method,formParams, getParams, null);
+    }
+    public static String HttpRestClient(String url, HttpMethod method, Map<String, String> formParams, MediaType mediaType) {
+        return HttpRestClient(url,method,formParams, null, mediaType);
+    }
 
+    public static String HttpRestClient(String url, HttpMethod method, Map<String, String> formParams, String getParams,  MediaType mediaType) {
+        if (!StringUtils.isEmpty(getParams)) {
+            url = url + Constant.QUESTION + getParams;
+        }
+        SimpleClientHttpRequestFactory requestFactory = new SimpleClientHttpRequestFactory();
+        requestFactory.setConnectTimeout(10*1000);
+        requestFactory.setReadTimeout(10*1000);
+        RestTemplate client = new RestTemplate(requestFactory);
+        client.getMessageConverters().set(1,new StringHttpMessageConverter(StandardCharsets.UTF_8));
+        HttpHeaders headers = new HttpHeaders();
+        HttpEntity requestEntity;
+        if (mediaType == null){
+            headers.setContentType(MediaType.APPLICATION_FORM_URLENCODED);
+            MultiValueMap<String, String> vals = new LinkedMultiValueMap();
+
+            Set<String> keySet = formParams.keySet();
+            for (String key : keySet) {
+                String s = formParams.get(key);
+                List<String> strings = new ArrayList<>();
+                strings.add(s);
+                vals.put(key,strings);
+            }
+
+            requestEntity = new HttpEntity<MultiValueMap<String, String>>(vals, headers);
+        }else {
+            headers.setContentType(mediaType);
+            requestEntity = new HttpEntity<Map<String, String>>(formParams, headers);
+        }
+
+        //  鎵цHTTP璇锋眰
+        ResponseEntity<String> response = client.exchange(url, method, requestEntity, String.class);
+
+        String body = response.getBody();
+        log.info(MessageFormat.format("璇锋眰澶栭儴鎺ュ彛锛歶rl锛歿0}, 杩斿洖缁撴灉锛歿1}", url, body));
+        return body;
+    }
+
+    public static String HttpRestClientByObjectParams(String url, HttpMethod method, Map<String, Object> formParams, String getParams,Map<String,String> headerValMap,  MediaType mediaType) {
+        if (!StringUtils.isEmpty(getParams)) {
+            url = url + Constant.QUESTION + getParams;
+        }
+        SimpleClientHttpRequestFactory requestFactory = new SimpleClientHttpRequestFactory();
+        requestFactory.setConnectTimeout(10*1000);
+        requestFactory.setReadTimeout(10*1000);
+        RestTemplate client = new RestTemplate(requestFactory);
+        client.getMessageConverters().set(1,new StringHttpMessageConverter(StandardCharsets.UTF_8));
+        HttpHeaders headers = new HttpHeaders();
+        if (mediaType == null){
+            headers.setContentType(MediaType.APPLICATION_FORM_URLENCODED);
+        }else {
+            headers.setContentType(mediaType);
+        }
+        if (headerValMap != null) {
+            headers.setAll(headerValMap);
+        }
+        HttpEntity<Map<String, Object>> requestEntity = new HttpEntity<Map<String, Object>>(formParams, headers);
+        //  鎵цHTTP璇锋眰
+        ResponseEntity<String> response = client.exchange(url, method, requestEntity, String.class);
+
+        String body = response.getBody();
+        log.info(MessageFormat.format("璇锋眰澶栭儴鎺ュ彛锛歶rl锛歿0}, 杩斿洖缁撴灉锛歿1}", url, body));
+        return body;
+    }
+
+    public static String getUrlParamsByMap(Map<String, Object> map) {
+        if (map == null) {
+            return "";
+        }
+        StringBuffer sb = new StringBuffer();
+        for (Map.Entry<String, Object> entry : map.entrySet()) {
+            Object mapValue = entry.getValue();
+            if (mapValue instanceof List) {
+               List<Object> valueList = (List<Object>) mapValue;
+                mapValue = valueList.stream().map(value -> value.toString()).collect(Collectors.joining(Constant.SEMICOLON));
+            }
+            sb.append(entry.getKey() + "=" + mapValue);
+            sb.append("&");
+        }
+        String s = sb.toString();
+        if (s.endsWith("&")) {
+            s = org.apache.commons.lang.StringUtils.substringBeforeLast(s, "&");
+        }
+        return s;
+    }
 }

--
Gitblit v1.8.0