mac
2023-12-20 0f91b37f7711481b9671409d0de08873d77060eb
app/src/main/java/com/hdl/photovoltaic/other/HdlOtaLogic.java
@@ -17,7 +17,6 @@
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.config.UserConfigManage;
import com.hdl.photovoltaic.internet.HttpClient;
import com.hdl.photovoltaic.internet.HttpServer.MyNanoHttpServer;
@@ -32,9 +31,7 @@
import com.hdl.photovoltaic.utils.Md5Utils;
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;
@@ -93,7 +90,7 @@
    /**
     * 服务是否开启 true=开启
     */
    public boolean mServiceStart= false;
    public boolean mServiceStart = false;
    /**
     * true表示终止下载升级文件(用户行为)
@@ -525,72 +522,6 @@
        }
    }
    /**
     * 【测试】处理下载文件数据
     *
     * @param zipData 文件数据流对象
     * @param md5     检验文件MD5值
     * @return 返回解密的byte[]
     */
    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, "正常上报");
                }
            }
            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 +536,13 @@
        this.stopDownload = false;
        //-100:没有数据;-101:没有md5秘钥;-102:md5秘钥不对;-103:有异常;
        if (zipData == null) {
            this.eventBusPost(fileFullPath, driver, -100, "没有数据");
            this.eventBusPost(fileFullPath, driver, -100, "拉不到云端升级文件数据");
            HdlLogLogic.print("拉不到云端升级文件数据(-100)", true);
            return false;
        }
        if (TextUtils.isEmpty(md5)) {
            this.eventBusPost(fileFullPath, driver, -101, "没有md5秘钥");
            this.eventBusPost(fileFullPath, driver, -101, "拿不到云端上升级文件md5秘钥");
            HdlLogLogic.print("拿不到云端上升级文件md5秘钥(-101)", true);
            return false;
        }
        InputStream is = null;
@@ -622,14 +555,16 @@
            is = zipData.byteStream();
            long total = zipData.contentLength();
            if (total == 0) {
                this.eventBusPost(fileFullPath, driver, -100, "没有数据");
                this.eventBusPost(fileFullPath, driver, -102, "拉不到云端升级文件数据");
                HdlLogLogic.print("拉不到云端升级文件数据(-102)", true);
                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, "用户取消下载升级文件.");
                    HdlLogLogic.print("用户取消下载升级文件(-108)", true);
                    fos.flush();
                    fos.close();
                    is.close();
@@ -642,7 +577,8 @@
                int progress = (int) (100 * sum * 1.0f / total);
                if (sum != total) {
                    //不等于100都要报,等于100处理整块逻辑完之后再报100;
                    this.eventBusPost(fileFullPath, driver, progress, "正常上报");
                    this.eventBusPost(fileFullPath, driver, progress, "正常上报进度值->" + progress);
                    HdlLogLogic.print("正常上报进度值->" + progress, true);
                }
            }
            fos.flush();
@@ -652,21 +588,25 @@
            //下载文件需要解密之后再进行md5去做比对
            byte[] decrypt = AesUtils.decrypt(bytes);
            if (decrypt == null) {
                this.eventBusPost(fileFullPath, driver, -105, "aes解密失败.");
                this.eventBusPost(fileFullPath, driver, -105, "升级文件aes解密失败.");
                HdlLogLogic.print("升级文件aes解密失败(-105)", true);
                return false;
            }
            String fileMD5 = Md5Utils.encodeMD5(decrypt);
            if (TextUtils.isEmpty(fileMD5)) {
                this.eventBusPost(fileFullPath, driver, -106, "文件生成md5失败.");
                this.eventBusPost(fileFullPath, driver, -106, "升级文件生成md5失败失败.");
                HdlLogLogic.print("升级文件生成md5失败失败(-106)", true);
                return false;
            }
            if (!md5.equals(fileMD5)) {
                this.eventBusPost(fileFullPath, driver, -107, "md5比对失败.");
                this.eventBusPost(fileFullPath, driver, -107, "升级文件md5比对失败.");
                HdlLogLogic.print("升级文件md5比对失败(-107)", true);
                return false;
            }
            //todo 注意:解密之后,要重新写数据;
            FileUtils.writeByteArrayToFile(file, decrypt, false);
            this.eventBusPost(fileFullPath, driver, 100, "下载完成.");
            this.eventBusPost(fileFullPath, driver, 100, "升级文件下载完成.");
            HdlLogLogic.print("升级文件下载完成.", true);
            return true;
        } catch (Exception e) {
            this.eventBusPost(fileFullPath, driver, -103, e.getMessage());
@@ -684,7 +624,7 @@
     * @param describe      描述文本
     */
    public void eventBusPost(String fileFullPath, String type, int progressValue, String describe) {
        HdlLogLogic.print("进度值====" + progressValue + "");
        if (this.stopDownload) {
            HdlFileLogic.getInstance().deleteFile(fileFullPath);//删除下载不完整数据;