From 30859ca8f2175475d2c666353bc27f3b2ceede53 Mon Sep 17 00:00:00 2001 From: mac <user@users-MacBook-Pro.local> Date: 星期四, 22 八月 2024 13:43:47 +0800 Subject: [PATCH] 2024年08月22日13:43:45 --- app/src/main/java/com/hdl/photovoltaic/other/HdlOtaLogic.java | 112 +++++++++++-------------------------------------------- 1 files changed, 23 insertions(+), 89 deletions(-) diff --git a/app/src/main/java/com/hdl/photovoltaic/other/HdlOtaLogic.java b/app/src/main/java/com/hdl/photovoltaic/other/HdlOtaLogic.java index e1c7539..4606be1 100644 --- a/app/src/main/java/com/hdl/photovoltaic/other/HdlOtaLogic.java +++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlOtaLogic.java @@ -17,7 +17,7 @@ import com.hdl.linkpm.sdk.ota.bean.DeviceFirmwareBean; import com.hdl.linkpm.sdk.ota.bean.GatewayDriverBean; import com.hdl.photovoltaic.HDLApp; -import com.hdl.photovoltaic.config.AppConfigManage; +import com.hdl.photovoltaic.R; import com.hdl.photovoltaic.config.UserConfigManage; import com.hdl.photovoltaic.internet.HttpClient; import com.hdl.photovoltaic.internet.HttpServer.MyNanoHttpServer; @@ -28,25 +28,21 @@ import com.hdl.photovoltaic.listener.CloudCallBeak; import com.hdl.photovoltaic.listener.LinkCallBack; import com.hdl.photovoltaic.utils.AesUtils; -import com.hdl.photovoltaic.utils.AppManagerUtils; import com.hdl.photovoltaic.utils.Md5Utils; +import com.hdl.photovoltaic.utils.NetworkUtils; import com.hdl.sdk.link.common.exception.HDLLinkException; import com.hdl.sdk.link.core.bean.eventbus.BaseEventBus; -import com.hdl.sdk.link.core.bean.gateway.GatewayBean; import com.hdl.sdk.link.core.callback.HDLLinkCallBack; -import com.hdl.sdk.link.gateway.HDLLinkLocalGateway; import org.apache.commons.io.FileUtils; import org.greenrobot.eventbus.EventBus; import java.io.File; import java.io.FileOutputStream; -import java.io.IOException; import java.io.InputStream; import java.lang.reflect.Type; import java.util.ArrayList; import java.util.List; -import java.util.Objects; import okhttp3.ResponseBody; @@ -93,7 +89,7 @@ /** * 鏈嶅姟鏄惁寮�鍚� true=寮�鍚� */ - public boolean mServiceStart= false; + public boolean mServiceStart = false; /** * true琛ㄧず缁堟涓嬭浇鍗囩骇鏂囦欢(鐢ㄦ埛琛屼负) @@ -505,7 +501,7 @@ //1,寤虹珛鏈湴鏈嶅姟锛� //2锛屽憡璇夌綉鍏虫墜鏈篿p鍜岀鍙o紱 //瀹炰緥鍖� 鑾峰彇ip 鍦板潃 - MyNanoHttpServer.getInstance(AppManagerUtils.getAppManager().getIPAddress(HDLApp.getInstance())); + MyNanoHttpServer.getInstance(NetworkUtils.getIPAddress(HDLApp.getInstance())); //MyNanoHttpServer.getInstance("127.0.0.1"); intentServer = new Intent(); intentServer.setClass(HDLApp.getInstance(), MyNanoHttpService.class); @@ -525,72 +521,6 @@ } } - /** - * 銆愭祴璇曘�戝鐞嗕笅杞芥枃浠舵暟鎹� - * - * @param zipData 鏂囦欢鏁版嵁娴佸璞� - * @param md5 妫�楠屾枃浠禡D5鍊� - * @return 杩斿洖瑙e瘑鐨刡yte[] - */ - public boolean testDisposeDownLoadFile(String fullPath, ResponseBody zipData, String md5) { - String driver = driver_type; - //-100:娌℃湁鏁版嵁;-101:娌℃湁md5绉橀挜;-102:md5绉橀挜涓嶅;-103:鏈夊紓甯�; - if (zipData == null) { - this.eventBusPost(fullPath, driver, -100, "娌℃湁鏁版嵁"); - return false; - } - if (TextUtils.isEmpty(md5)) { - this.eventBusPost(fullPath, driver, -101, "娌℃湁md5绉橀挜"); - return false; - } - InputStream is = null; - byte[] buf = new byte[1204 * 4]; - int len = 0; - FileOutputStream fos = null; - File file = null; - try { - file = new File(fullPath); - is = zipData.byteStream(); - long total = zipData.contentLength(); - if (total == 0) { - this.eventBusPost(fullPath, driver, -100, "娌℃湁鏁版嵁"); - return false; - } - fos = new FileOutputStream(file); - long sum = 0; - while ((len = is.read(buf)) != -1) { - fos.write(buf, 0, len); - sum += len; - //todo 涓嬭浇涓紝鍙互鑷繁璁$畻鐨勮繘搴︽潯(鍙互骞挎挱鍑哄幓) - int progress = (int) (100 * sum * 1.0f / total); - if (sum != total) { - //涓嶇瓑浜�100閮借鎶�,绛変簬100澶勭悊鏁村潡閫昏緫瀹屼箣鍚庡啀鎶�100; - this.eventBusPost(fullPath, driver, progress, "姝e父涓婃姤"); - } - } - fos.flush(); - fos.close(); - is.close(); - byte[] bytes = FileUtils.readFileToByteArray(file); - String fileMD5 = Md5Utils.encodeMD5(bytes); - if (TextUtils.isEmpty(fileMD5)) { - this.eventBusPost(fullPath, driver, -106, "鏂囦欢鐢熸垚md5澶辫触."); - return false; - } - if (!md5.equals(fileMD5)) { - this.eventBusPost(fullPath, driver, -107, "md5姣斿澶辫触."); - return false; - } - this.eventBusPost(fullPath, driver, 100, "涓嬭浇瀹屾垚."); - - - return true; - } catch (Exception e) { - this.eventBusPost(fullPath, driver, -103, e.getMessage()); - e.printStackTrace(); - } - return false; - } /** * 澶勭悊涓嬭浇鏂囦欢鏁版嵁 @@ -605,11 +535,11 @@ this.stopDownload = false; //-100:娌℃湁鏁版嵁;-101:娌℃湁md5绉橀挜;-102:md5绉橀挜涓嶅;-103:鏈夊紓甯�; if (zipData == null) { - this.eventBusPost(fileFullPath, driver, -100, "娌℃湁鏁版嵁"); + this.eventBusPost(fileFullPath, driver, -100, HDLApp.getInstance().getString(R.string.exception_unable_to_pull_up_the_cloud_upgrade_file_data)); return false; } if (TextUtils.isEmpty(md5)) { - this.eventBusPost(fileFullPath, driver, -101, "娌℃湁md5绉橀挜"); + this.eventBusPost(fileFullPath, driver, -101, HDLApp.getInstance().getString(R.string.exception_failed_to_obtain_the_md5_key_of_the_upgrade_file_on_the_cloud)); return false; } InputStream is = null; @@ -622,14 +552,14 @@ is = zipData.byteStream(); long total = zipData.contentLength(); if (total == 0) { - this.eventBusPost(fileFullPath, driver, -100, "娌℃湁鏁版嵁"); + this.eventBusPost(fileFullPath, driver, -102, HDLApp.getInstance().getString(R.string.exception_unable_to_pull_up_the_cloud_upgrade_file_data)); return false; } fos = new FileOutputStream(file); long sum = 0; while ((len = is.read(buf)) != -1) { if (this.stopDownload) { - this.eventBusPost(fileFullPath, driver, -108, "鐢ㄦ埛鍙栨秷涓嬭浇."); + this.eventBusPost(fileFullPath, driver, -108, HDLApp.getInstance().getString(R.string.exception_the_user_cancels_downloading_the_upgrade_file)); fos.flush(); fos.close(); is.close(); @@ -642,31 +572,33 @@ int progress = (int) (100 * sum * 1.0f / total); if (sum != total) { //涓嶇瓑浜�100閮借鎶�,绛変簬100澶勭悊鏁村潡閫昏緫瀹屼箣鍚庡啀鎶�100; - this.eventBusPost(fileFullPath, driver, progress, "姝e父涓婃姤"); + this.eventBusPost(fileFullPath, driver, progress, "姝e父涓婃姤杩涘害鍊�---" + progress); } } fos.flush(); fos.close(); is.close(); - byte[] bytes = FileUtils.readFileToByteArray(file); - //涓嬭浇鏂囦欢闇�瑕佽В瀵嗕箣鍚庡啀杩涜md5鍘诲仛姣斿 + byte[] bytes = HdlFileLogic.getInstance().readFileByte(fileFullPath); +// byte[] bytes = FileUtils.readFileToByteArray(file);//杩欎釜鏂规硶涓嶅吋鐢╝ndroid 6.0 + //todo 涓嬭浇鏂囦欢闇�瑕佽В瀵嗕箣鍚庡啀杩涜md5鍘诲仛姣斿 byte[] decrypt = AesUtils.decrypt(bytes); if (decrypt == null) { - this.eventBusPost(fileFullPath, driver, -105, "aes瑙e瘑澶辫触."); + this.eventBusPost(fileFullPath, driver, -105, HDLApp.getInstance().getString(R.string.exception_failed_to_decrypt_the_upgrade_aes_file)); return false; } String fileMD5 = Md5Utils.encodeMD5(decrypt); if (TextUtils.isEmpty(fileMD5)) { - this.eventBusPost(fileFullPath, driver, -106, "鏂囦欢鐢熸垚md5澶辫触."); + this.eventBusPost(fileFullPath, driver, -106, HDLApp.getInstance().getString(R.string.exception_failed_to_generate_md5_for_the_upgrade_file)); return false; } if (!md5.equals(fileMD5)) { - this.eventBusPost(fileFullPath, driver, -107, "md5姣斿澶辫触."); + this.eventBusPost(fileFullPath, driver, -107, HDLApp.getInstance().getString(R.string.exception_description_failed_to_compare_the_md5_of_the_upgrade_file)); return false; } //todo 娉ㄦ剰:瑙e瘑涔嬪悗锛岃閲嶆柊鍐欐暟鎹�; - FileUtils.writeByteArrayToFile(file, decrypt, false); - this.eventBusPost(fileFullPath, driver, 100, "涓嬭浇瀹屾垚."); + HdlFileLogic.getInstance().writeFile(fileFullPath, decrypt); +// FileUtils.writeByteArrayToFile(file, decrypt, false);//杩欎釜鏂规硶涓嶅吋鐢╝ndroid 6.0 + this.eventBusPost(fileFullPath, driver, 100, HDLApp.getInstance().getString(R.string.exception_the_upgrade_file_is_downloaded)); return true; } catch (Exception e) { this.eventBusPost(fileFullPath, driver, -103, e.getMessage()); @@ -684,15 +616,16 @@ * @param describe 鎻忚堪鏂囨湰 */ public void eventBusPost(String fileFullPath, String type, int progressValue, String describe) { - HdlLogLogic.print("杩涘害鍊�====" + progressValue + ""); + if (this.stopDownload) { - HdlFileLogic.getInstance().deleteFile(fileFullPath);//鍒犻櫎涓嬭浇涓嶅畬鏁存暟鎹�; +// HdlFileLogic.getInstance().deleteFile(fileFullPath);//鍒犻櫎涓嬭浇涓嶅畬鏁存暟鎹�; + //鍙栨秷涓嬭浇骞挎挱涓�娆� BaseEventBus baseEventBus = new BaseEventBus(); baseEventBus.setTopic(localDownloadProgress); Progress progress = new Progress(); progress.step = -108; - progress.describe = "鐢ㄦ埛鍙栨秷涓嬭浇."; + progress.describe = describe; baseEventBus.setType(type); baseEventBus.setData(progress); EventBus.getDefault().post(baseEventBus); @@ -720,6 +653,7 @@ //鑷畾涔変笂鎶ヤ笅杞介┍鍔ㄦ垨鍥轰欢杩涘害涓婚 public static final String localDownloadProgress = "cloud/download/progress/up"; + public static final String driver_type = "driver"; public static final String firmware_type = "firmware"; -- Gitblit v1.8.0