From 381cc44f30a98d8719463fdd2a091ff7217f2545 Mon Sep 17 00:00:00 2001
From: wangrenhuang <wangren_huang@163.com>
Date: 星期四, 19 十月 2023 16:13:17 +0800
Subject: [PATCH] 新增公众号发送小程序卡片客户消息方法

---
 src/main/java/com/hz/util/http/HttpHzUtil.java |   58 +++++++++++++++++++++++++++++++++++-----------------------
 1 files changed, 35 insertions(+), 23 deletions(-)

diff --git a/src/main/java/com/hz/util/http/HttpHzUtil.java b/src/main/java/com/hz/util/http/HttpHzUtil.java
index 3f4fce1..1f8e24e 100644
--- a/src/main/java/com/hz/util/http/HttpHzUtil.java
+++ b/src/main/java/com/hz/util/http/HttpHzUtil.java
@@ -6,25 +6,32 @@
 
 import java.io.OutputStream;
 import java.net.HttpURLConnection;
+import java.net.SocketTimeoutException;
 import java.net.URL;
 import java.util.Iterator;
 import java.util.Map;
 
 public class HttpHzUtil {
 
-    /**璇锋眰鏂规硶*/
-    public  static final String METHOD_POST = "POST";
-    /**缂栫爜*/
-    public  static final String CHARSET = "UTF-8";
+    /**
+     * 璇锋眰鏂规硶
+     */
+    public static final String METHOD_POST = "POST";
+    /**
+     * 缂栫爜
+     */
+    public static final String CHARSET = "UTF-8";
 
 
-    /**璇锋眰
-     * @param url 璇锋眰閾炬帴
-     * @param bodyData 璇锋眰body鏁版嵁
-     * @param keyValues 杩炴帴鎼哄甫鍙傛暟
-     * @param header 琛ㄥご鎼哄甫鍙傛暟
+    /**
+     * 璇锋眰
+     *
+     * @param url           璇锋眰閾炬帴
+     * @param bodyData      璇锋眰body鏁版嵁
+     * @param keyValues     杩炴帴鎼哄甫鍙傛暟
+     * @param header        琛ㄥご鎼哄甫鍙傛暟
      * @param requestMethod 璇锋眰绫诲瀷锛岄粯璁わ細POST
-     * @param outTime 瓒呮椂鏃堕棿锛堟绉掞級,榛樿锛�300000
+     * @param outTime       瓒呮椂鏃堕棿锛堟绉掞級,榛樿锛�300000
      * @return
      */
     public static HttpHzResponse HttpURLUtilJson(String url, String bodyData, Map<String, Object> keyValues, Map<String, String> header, String requestMethod, Integer outTime) {
@@ -37,9 +44,9 @@
             if (keyValues != null && !keyValues.isEmpty()) {
                 var9 = keyValues.entrySet().iterator();
 
-                while(var9.hasNext()) {
-                    entry = (Map.Entry)var9.next();
-                    dataP.append((String)entry.getKey()).append("=");
+                while (var9.hasNext()) {
+                    entry = (Map.Entry) var9.next();
+                    dataP.append((String) entry.getKey()).append("=");
                     dataP.append(entry.getValue());
                     dataP.append("&");
                 }
@@ -52,12 +59,12 @@
                 requestMethod = METHOD_POST;
             }
 
-            if(outTime == null || outTime < 0){
+            if (outTime == null || outTime < 0) {
                 outTime = 300000;
             }
 
             URL httpUrl = new URL(url);
-            con = (HttpURLConnection)httpUrl.openConnection();
+            con = (HttpURLConnection) httpUrl.openConnection();
             con.setRequestMethod(requestMethod);
             con.setDoOutput(true);
             con.setDoInput(true);
@@ -68,9 +75,9 @@
             if (header != null) {
                 var9 = header.entrySet().iterator();
 
-                while(var9.hasNext()) {
-                    entry = (Map.Entry)var9.next();
-                    con.setRequestProperty((String)entry.getKey(), (String)entry.getValue());
+                while (var9.hasNext()) {
+                    entry = (Map.Entry) var9.next();
+                    con.setRequestProperty((String) entry.getKey(), (String) entry.getValue());
                 }
             }
 
@@ -79,15 +86,20 @@
                 os.write(bodyData.getBytes(CHARSET));
             }
 
-            if(HttpHzResponse.CODE_200.equals(con.getResponseCode())){
-                httpHzResponse.setCode(con.getResponseCode()+"");
-                httpHzResponse.setData(IOUtils.toString(con.getInputStream(), CHARSET));
-            }else{
-                httpHzResponse.setCode(con.getResponseCode()+"");
+            httpHzResponse.setCode(con.getResponseCode() + "");
+            if (con.getErrorStream() != null) {
                 httpHzResponse.setMsg(IOUtils.toString(con.getErrorStream(), CHARSET));
             }
+            if (HttpURLConnection.HTTP_OK == con.getResponseCode() || HttpURLConnection.HTTP_CREATED == con.getResponseCode()) {
+                httpHzResponse.setData(IOUtils.toString(con.getInputStream(), CHARSET));
+            }
 
+        }catch (SocketTimeoutException var15) {
+            httpHzResponse.setMsg(var15.getMessage());
+            httpHzResponse.setCode(HttpHzResponse.CODE_TIME_OUT);
+            var15.printStackTrace();
         } catch (Exception var14) {
+            httpHzResponse.setMsg(var14.getMessage());
             var14.printStackTrace();
         } finally {
             if (con != null) {

--
Gitblit v1.8.0