From af262dee3a741902a564ae019ebbf0d47add210c Mon Sep 17 00:00:00 2001 From: mac <user@users-MacBook-Pro.local> Date: 星期二, 26 十二月 2023 20:24:13 +0800 Subject: [PATCH] 2023年12月26日20:24:04 --- app/src/main/java/com/hdl/photovoltaic/other/HdlFileLogic.java | 83 +++++++++++++++++++++++++++-------------- 1 files changed, 55 insertions(+), 28 deletions(-) diff --git a/app/src/main/java/com/hdl/photovoltaic/other/HdlFileLogic.java b/app/src/main/java/com/hdl/photovoltaic/other/HdlFileLogic.java index 012a181..b9d92d0 100644 --- a/app/src/main/java/com/hdl/photovoltaic/other/HdlFileLogic.java +++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlFileLogic.java @@ -7,6 +7,8 @@ import com.hdl.photovoltaic.HDLApp; import com.hdl.photovoltaic.config.UserConfigManage; +import org.apache.commons.io.FileUtils; + import java.io.BufferedInputStream; import java.io.BufferedOutputStream; import java.io.BufferedReader; @@ -117,8 +119,21 @@ * @return 鍏ㄨ矾寰� */ public String getDrivePathFileName(String driverCode, String version) { - String driverFileName = driverCode + "_" + version + ".zip"; - return HdlFileLogic.getInstance().getDriveRootPath() + "/" + driverFileName; + String fileName = driverCode + "_" + version + ".zip"; + return HdlFileLogic.getInstance().getDriveRootPath() + "/" + fileName; + } + + /** + * 鑾峰彇鍥轰欢鍗囩骇鏂囦欢鍏ㄨ矾寰� + * + * @param oid 璇ュ浐浠秓id + * @param imageId 闀滃儚id + * @param version 椹卞姩鐗堟湰 + * @return 鍏ㄨ矾寰� + */ + public String getFirmwarePathFileName(String oid, String imageId, String version) { + String fileName = oid + "_" + imageId + "_" + version + ".zip"; + return HdlFileLogic.getInstance().getFirmwareRootPath() + "/" + fileName; } //endregion @@ -149,7 +164,7 @@ File file = new File(fullPath); if (!file.isDirectory()) { boolean succeed = file.mkdirs(); - System.out.println("鍒涘缓鏂囦欢澶硅矾寰�=" + file.getAbsolutePath() + "->->鍒涘缓鏂囦欢澶圭粨鏋�=" + succeed); + System.out.println("鍒涘缓鏂囦欢澶硅矾寰�--->" + file.getAbsolutePath() + "===鍒涘缓鏂囦欢澶圭粨鏋�--->" + succeed); return succeed; } return true; @@ -182,7 +197,7 @@ } // 鍒犻櫎鏂囦欢澶规湰韬� boolean succeed = fileRoot.delete();//鏂囦欢澶圭┖杩欎釜鏂规硶鎵嶆湁鏁� - System.out.println("鍒犻櫎鏂囦欢澶硅矾寰�=" + fileRoot.getAbsolutePath() + "->->鍒犻櫎缁撴灉=" + succeed); + System.out.println("鍒犻櫎鏂囦欢澶硅矾寰�--->" + fileRoot.getAbsolutePath() + "===鍒犻櫎缁撴灉--->" + succeed); } catch (Exception e) { System.out.println("鍒犻櫎鏂囦欢澶规湁寮傚父===" + e.getMessage()); } @@ -205,7 +220,7 @@ File file = new File(fullPath); if (!file.exists()) { boolean succeed = file.createNewFile(); - System.out.println("鍒涘缓鏂囦欢璺緞=" + file.getAbsolutePath() + "->->鍒涘缓鏂囦欢缁撴灉=" + succeed); + System.out.println("鍒涘缓鏂囦欢璺緞--->" + file.getAbsolutePath() + "===鍒涘缓鏂囦欢缁撴灉--->" + succeed); return succeed; } return true; @@ -226,7 +241,7 @@ File file = new File(fullPath); if (file.exists()) { boolean succeed = file.delete(); - System.out.println("鍒犻櫎鏂囦欢===" + succeed); + System.out.println("鍒犻櫎鏂囦欢--->" + fullPath + "===缁撴灉--->" + succeed); return succeed; } return true; @@ -257,9 +272,9 @@ d.write(data); d.flush(); d.close(); - System.out.println("鍐欏叆鏂囦欢鎴愬姛==" + fullPath); + System.out.println("鍐欏叆鏂囦欢鎴愬姛--->" + fullPath); } catch (Exception e) { - System.out.println("鍐欏叆鏂囦欢鏈夊紓甯�==" + e.getMessage()); + System.out.println("鍐欏叆鏂囦欢鏈夊紓甯�--->" + e.getMessage()); } } @@ -301,9 +316,9 @@ //鏂囦欢澶т簬1m,鍒犻櫎鏂囦欢鍓�10鏉℃棩蹇� this.delFileLien(fullPath, 10); } - System.out.println("鍐欏叆涓�琛屾暟鎹埌鏂囦欢鎴愬姛===" + dataLine); + System.out.println("鍐欏叆涓�琛屾暟鎹埌鏂囦欢鎴愬姛--->" + dataLine); } catch (Exception e) { - System.out.println("鍐欏叆涓�琛屾暟鎹埌鏂囦欢鏈夊紓甯�===" + e.getMessage()); + System.out.println("鍐欏叆涓�琛屾暟鎹埌鏂囦欢鏈夊紓甯�--->" + e.getMessage()); } } @@ -324,25 +339,12 @@ return null; } FileInputStream fis = new FileInputStream(f); -// byte[] bytes = new byte[fis.available()]; - byte[] readByte = new byte[1024]; - List<Byte> byteList = new ArrayList<>(); - int len = 0; - while ((len = fis.read(readByte)) != -1) { - for (int i = 0; i < len; i++) { - byteList.add(readByte[i]); - } - } - Byte[] forbByte = byteList.toArray(new Byte[0]); - byte[] bytes = new byte[forbByte.length]; - for (int i = 0; i < forbByte.length; i++) { - bytes[i] = forbByte[i]; - } + byte[] bytes = FileUtils.readFileToByteArray(f); fis.close(); - System.out.println("璇诲彇鏂囦欢鎴愬姛===" + filePath); + System.out.println("璇诲彇鏂囦欢鎴愬姛--->" + filePath); return bytes; } catch (Exception e1) { - System.out.println("璇诲彇鏂囦欢鏈夊紓甯�===" + e1.getMessage()); + System.out.println("璇诲彇鏂囦欢鏈夊紓甯�--->" + e1.getMessage()); return null; } @@ -356,7 +358,6 @@ */ public String readFile(String filePath) { try { - byte[] bytes = readFileByte(filePath); if (bytes == null) { return ""; @@ -367,6 +368,32 @@ } } + + /** + * 璇诲彇鏂囦欢 + * + * @param filePath 鍏ㄨ矾寰� + * @return 鏁版嵁 + */ + public FileInputStream fileStream(String filePath) { + try { + if (!isBoolean(filePath)) { + return null; + } + File f = new File(filePath); + if (!f.exists()) { + return null; + } + fileLength = f.length(); + return new FileInputStream(f); + } catch (Exception e1) { + System.out.println("璇诲彇鏂囦欢鏈夊紓甯�--->" + e1.getMessage()); + return null; + } + + } + + public static long fileLength = 0; /** * 鎸囧畾鍒犻櫎鏂囦欢琛屾暟锛堜粠鍓嶉潰鍒犻櫎璧凤級 @@ -416,7 +443,7 @@ */ public boolean isBoolean(String path) { if (path.contains("//") || path.contains("\\")) { - System.out.println("鏃犳晥鏂囦欢璺緞===" + path); + System.out.println("鏃犳晥鏂囦欢璺緞--->" + path); return false; } return true; -- Gitblit v1.8.0