From 54a8c79222bba0644b02fe1dbc5d75e26ea50b5d Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期二, 14 十一月 2023 18:17:58 +0800
Subject: [PATCH] 2023年11月14日18:17:48

---
 app/src/main/java/com/hdl/photovoltaic/internet/HttpClient.java |  111 +++++++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 90 insertions(+), 21 deletions(-)

diff --git a/app/src/main/java/com/hdl/photovoltaic/internet/HttpClient.java b/app/src/main/java/com/hdl/photovoltaic/internet/HttpClient.java
index 850f6cb..e4f21cd 100644
--- a/app/src/main/java/com/hdl/photovoltaic/internet/HttpClient.java
+++ b/app/src/main/java/com/hdl/photovoltaic/internet/HttpClient.java
@@ -9,6 +9,7 @@
 import com.google.gson.JsonObject;
 import com.google.gson.reflect.TypeToken;
 import com.hdl.hdlhttp.HxHttp;
+import com.hdl.hdlhttp.HxHttpBuilder;
 import com.hdl.hdlhttp.utils.GsonConvert;
 import com.hdl.linkpm.sdk.core.api.HDLCloudUserApi;
 import com.hdl.linkpm.sdk.core.exception.HDLException;
@@ -20,9 +21,11 @@
 import com.hdl.photovoltaic.config.AppConfigManage;
 import com.hdl.photovoltaic.config.UserConfigManage;
 import com.hdl.photovoltaic.listener.BaseSuccessFailureCallBeak;
+import com.hdl.photovoltaic.listener.CloudCallBeak;
 import com.hdl.photovoltaic.other.HdlLogLogic;
 import com.hdl.photovoltaic.utils.HDLMD5Utils;
 
+import java.io.File;
 import java.io.IOException;
 import java.util.ArrayList;
 import java.util.Collections;
@@ -34,6 +37,7 @@
 import okhttp3.Call;
 import okhttp3.Callback;
 import okhttp3.FormBody;
+import okhttp3.Headers;
 import okhttp3.MediaType;
 import okhttp3.OkHttpClient;
 import okhttp3.Request;
@@ -61,22 +65,28 @@
      * 搴曞眰鏂规硶,寮曠敤搴撶殑鏂规硶
      *
      * @param api      璇锋眰鎺ュ彛
-     * @param body     璇锋眰鍙傛暟
+     * @param body     璇锋眰鍙傛暟(appKey,timestamp,sign杩欎笁涓弬鏁板唴閮ㄤ細鑷姩娣诲姞))
      * @param callBack 鍥炶皟
      * @return -
      */
-    private Disposable request(String api, String body, BaseSuccessFailureCallBeak callBack) {
+    private Disposable request(String api, String body, CloudCallBeak<String> callBack) {
+
+
         String requestUrl = HDLCloudUserApi.getRequestUrl(api);
+        Gson gson = new Gson();
+        System.out.println("http->鍙戦��->" + requestUrl + "\r\n" + body);
         return HxHttp.builder()
                 .url(requestUrl)
                 .raw(body)
                 .build()
                 .post()
-                .subscribeWith(new HDLResponse<HttpResponsePack>() {
+                .subscribeWith(new HDLResponse<String>() {
                     @Override
-                    public void onResponse(HttpResponsePack response) {
+                    public void onResponse(String str) {
                         if (callBack != null) {
-                            callBack.onSuccess(response);
+                            callBack.onSuccess(str);
+//                          System.out.println("http->鍥炲->" + requestUrl + "\r\n" + gson.fromJson(str, JsonObject.class).toString());
+                            System.out.println("http->鍥炲->" + requestUrl + "\r\n" + str);
                         }
                     }
 
@@ -85,6 +95,7 @@
                         HDLExceptionSubmitUtils.submit(requestUrl, body, e);
                         if (callBack != null) {
                             callBack.onFailure(e);
+                            System.out.println("http->鍥炲->" + requestUrl + "\r\n" + "\"{code=\"" + e.getCode() + "," + "\"message=\"" + e.getMsg() + "}");
                         }
                     }
                 });
@@ -93,38 +104,96 @@
 
     /**
      * 璇锋眰鏈嶅姟鍣�
+     * 搴曞眰鏂规硶,寮曠敤搴撶殑鏂规硶
+     *
+     * @param api      璇锋眰鎺ュ彛
+     * @param body     璇锋眰鍙傛暟(appKey,timestamp,sign杩欎笁涓弬鏁板唴閮ㄤ細鑷姩娣诲姞))
+     * @param callBack 鍥炶皟
+     * @return -
+     */
+    private Disposable requestFile(String api, File body, CloudCallBeak<String> callBack) {
+
+
+        String requestUrl = HDLCloudUserApi.getRequestUrl(api);
+        Gson gson = new Gson();
+        System.out.println("http->鍙戦��->" + requestUrl + "\r\n" + body);
+        return HxHttp.builder()
+                .url(requestUrl)
+                .file(body)
+                .build()
+                .post()
+                .subscribeWith(new HDLResponse<String>() {
+                    @Override
+                    public void onResponse(String str) {
+                        if (callBack != null) {
+                            callBack.onSuccess(str);
+//                          System.out.println("http->鍥炲->" + requestUrl + "\r\n" + gson.fromJson(str, JsonObject.class).toString());
+                            HdlLogLogic.print("http->鍥炲->" + requestUrl + "\r\n" + str, true);
+                        }
+                    }
+
+                    @Override
+                    public void onFailure(HDLException e) {
+                        HDLExceptionSubmitUtils.submit(requestUrl, body, e);
+                        if (callBack != null) {
+                            callBack.onFailure(e);
+                            HdlLogLogic.print("http->鍥炲->" + requestUrl + "\r\n" + "\"{code=\"" + e.getCode() + "," + "\"message=\"" + e.getMsg() + "}", true);
+                        }
+                    }
+                });
+
+    }
+
+
+    /**
+     * 璇锋眰鏈嶅姟鍣�
      *
      * @param api      璇锋眰鎺ュ彛
      * @param body     璇锋眰鍙傛暟(json)
      * @param callBack 鍥炶皟
      */
-    public Disposable requestHttp(String api, String body, BaseSuccessFailureCallBeak callBack) {
+    public Disposable requestHttp(String api, String body, CloudCallBeak<String> callBack) {
         return request(api, body, callBack);
     }
 
     /**
-     * 璇锋眰鏈嶅姟鍣ㄧ殑鏂规硶
+     * 璇锋眰鏈嶅姟鍣紙涓婁紶鏂囦欢锛�
+     *
+     * @param api      璇锋眰鎺ュ彛
+     * @param body     璇锋眰鍙傛暟(json)
+     * @param callBack 鍥炶皟
+     */
+    public Disposable requestHttpFile(String api, File body, CloudCallBeak<String> callBack) {
+        return requestFile(api, body, callBack);
+    }
+
+
+    /**
+     * 璇锋眰鏈嶅姟鍣ㄧ殑鏂规硶(宸插純鐢�)
      *
      * @param requestUrl     璇锋眰鎺ュ彛
      * @param json           璇锋眰鏁版嵁
      * @param isBasicService 鏄惁鏄熀纭�鏈嶅姟鐨勬帴鍙�(鍩虹鏈嶅姟鐨勬帴鍙i渶瑕� appKey,timestamp,sign杩欎笁涓弬鏁�,褰撲负true鏃�,鍐呴儴浼氳嚜鍔ㄦ坊鍔�)
      * @param isExecute      鏄惁鏄悓姝�(true=鍚屾,false=寮傛)
      */
-    public void requestHttp(String requestUrl, String json, boolean isBasicService, boolean isExecute, BaseSuccessFailureCallBeak baseSuccessCallBeak) {
+    @Deprecated
+    private void requestHttp(String requestUrl, String json, boolean isBasicService, boolean isExecute, BaseSuccessFailureCallBeak baseSuccessCallBeak) {
         String fullUrl = AppConfigManage.getUserRegionUrl() + requestUrl;
-        this.requestHttps(fullUrl, json, isBasicService, isExecute, baseSuccessCallBeak);
+        this.requestHttpServer(fullUrl, json, isBasicService, isExecute, baseSuccessCallBeak);
     }
 
     /**
-     * 璇锋眰鏈嶅姟鍣ㄧ殑鏂规硶(鐩墠鍙敤鍦ㄨ幏鍙栬幏鍙栬处鍙峰尯鍩熶俊鎭�)
+     * 璇锋眰鏈嶅姟鍣ㄧ殑鏂规硶(宸插純鐢�)
+     * 鐩墠鍙敤鍦ㄨ幏鍙栬幏鍙栬处鍙峰尯鍩熶俊鎭�
      *
      * @param fullUrl        缁濆鍦板潃(鍦板潃+鎺ュ彛)
      * @param json           璇锋眰鏁版嵁
      * @param isBasicService 鏄惁鏄熀纭�鏈嶅姟鐨勬帴鍙�(鍩虹鏈嶅姟鐨勬帴鍙i渶瑕� appKey,timestamp,sign杩欎笁涓弬鏁�,褰撲负true鏃�,鍐呴儴浼氳嚜鍔ㄦ坊鍔�)
      * @param isExecute      鏄惁鏄悓姝�(true=鍚屾,false=寮傛)
      */
-    public void requestFullHttp(String fullUrl, String json, boolean isBasicService, boolean isExecute, BaseSuccessFailureCallBeak baseSuccessCallBeak) {
-        this.requestHttps(fullUrl, json, isBasicService, isExecute, baseSuccessCallBeak);
+    @Deprecated
+    private void requestFullHttp(String fullUrl, String json, boolean isBasicService, boolean isExecute, BaseSuccessFailureCallBeak baseSuccessCallBeak) {
+        this.requestHttpServer(fullUrl, json, isBasicService, isExecute, baseSuccessCallBeak);
     }
 
     /**
@@ -135,12 +204,12 @@
      * @param isBasicService 鏄惁鏄熀纭�鏈嶅姟鐨勬帴鍙�(鍩虹鏈嶅姟鐨勬帴鍙i渶瑕� appKey,timestamp,sign杩欎笁涓弬鏁�,褰撲负true鏃�,鍐呴儴浼氳嚜鍔ㄦ坊鍔�)
      * @param isExecute      鏄惁鏄悓姝�(true=鍚屾,false=寮傛)
      */
-    private void requestHttps(String fullUrl, String json, boolean isBasicService, boolean isExecute, BaseSuccessFailureCallBeak baseSuccessCallBeak) {
+    private void requestHttpServer(String fullUrl, String json, boolean isBasicService, boolean isExecute, BaseSuccessFailureCallBeak baseSuccessCallBeak) {
         new Thread(new Runnable() {
             @Override
             public void run() {
                 try {
-                    HdlLogLogic.print("http->鍙戦��->", fullUrl + "\r\n" + json);
+                    HdlLogLogic.print("http->鍙戦��->" + fullUrl + "\r\n" + json, false);
                     OkHttpClient okHttpClient = new OkHttpClient();
                     RequestBody requestBody = FormBody.create(MediaType.parse("application/json; charset=utf-8"), getJson(json));
                     final Request request = new Request.Builder()
@@ -153,12 +222,12 @@
                         if (response.isSuccessful()) {
                             String s = Objects.requireNonNull(response.body()).string();
                             HttpResponsePack httpResponsePack = new Gson().fromJson(s, HttpResponsePack.class);
-                            HdlLogLogic.print("http->鍥炲->", response.request().url() + "\r\n" + s);
+                            HdlLogLogic.print("http->鍥炲->" + response.request().url() + "\r\n" + s, false);
                             baseSuccessCallBeak.onSuccess(httpResponsePack);
 
                         } else {
                             //throw new IOException("Unexpected code " + response);
-                            baseSuccessCallBeak.onFailure(new Exception());
+                            baseSuccessCallBeak.onFailure(new HDLException(response.code(), response.message()));
                         }
                     } else {
 
@@ -166,7 +235,7 @@
                         call.enqueue(new Callback() {//寮傛
                             @Override
                             public void onFailure(@NonNull Call call, @NonNull IOException e) {
-                                HdlLogLogic.print("http->鍥炲->", "\r\n" + e.getMessage());
+                                HdlLogLogic.print("http->鍥炲->" + "\r\n" + e.getMessage(), false);
                             }
 
                             @Override
@@ -176,16 +245,16 @@
                                     String s = Objects.requireNonNull(response.body()).string();
                                     HttpResponsePack httpResponsePack = new Gson().fromJson(s, HttpResponsePack.class);
                                     baseSuccessCallBeak.onSuccess(httpResponsePack);
-                                    HdlLogLogic.print("http->鍥炲->", "\r\n" + s);
+                                    HdlLogLogic.print("http->鍥炲->" + "\r\n" + s, false);
                                 } else {
-                                    baseSuccessCallBeak.onFailure(new Exception());
+                                    baseSuccessCallBeak.onFailure(new HDLException(response.code(), response.message()));
                                 }
                             }
                         });
                     }
                 } catch (Exception e) {
-                    baseSuccessCallBeak.onFailure(e);
-                    HdlLogLogic.print("http->鍥炲->", "\r\n" + e.getMessage());
+                    baseSuccessCallBeak.onFailure(new HDLException(-100, e.getMessage()));
+                    HdlLogLogic.print("http->鍥炲->" + "\r\n" + e.getMessage(), false);
                 }
 
             }

--
Gitblit v1.8.0