From 3a38adf05aad83ca5b34d3037bd6380596b792e0 Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期三, 28 八月 2024 17:21:13 +0800
Subject: [PATCH] 1、通信中間件增加下控制器日志文件功能; 2、功能66解析中心IP和端口bug修改。

---
 pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/web/com/CommandCtrl.java |  102 +++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 102 insertions(+), 0 deletions(-)

diff --git a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/web/com/CommandCtrl.java b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/web/com/CommandCtrl.java
index b8914a4..0dcd9cc 100644
--- a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/web/com/CommandCtrl.java
+++ b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/web/com/CommandCtrl.java
@@ -1,5 +1,6 @@
 package com.dy.rtuMw.web.com;
 
+import com.dy.rtuMw.resource.ResourceUnit;
 import com.dy.rtuMw.server.ServerProperties;
 import com.dy.rtuMw.server.forTcp.TcpSessionCache;
 import com.dy.rtuMw.server.local.CommandInnerDeaLer;
@@ -10,9 +11,16 @@
 import com.dy.common.mw.protocol.CommandType;
 import com.dy.common.webUtil.BaseResponse;
 import com.dy.common.webUtil.BaseResponseUtils;
+import jakarta.servlet.ServletOutputStream;
+import jakarta.servlet.http.HttpServletRequest;
+import jakarta.servlet.http.HttpServletResponse;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.http.MediaType;
 import org.springframework.web.bind.annotation.*;
+
+import java.io.*;
+import java.util.ArrayList;
+import java.util.List;
 
 
 /**
@@ -32,6 +40,100 @@
         return BaseResponseUtils.buildSuccess("ok");
     }
 
+    /**
+     * 涓嬭浇鎺у埗鍣紙RTU锛変笂涓嬭鏁版嵁鐨刲og鏃ュ織鏂囦欢
+     * @param rtuAddr
+     * @param req
+     * @param rep
+     */
+    @GetMapping("/rtuLogFile")
+    public void rtuLogFile(String rtuAddr, HttpServletRequest req, HttpServletResponse rep){
+        File logFile = ResourceUnit.getInstance().getLogFile(rtuAddr + ".log") ;
+        if(logFile != null && logFile.exists()){
+            //鍦⊿pring Boot涓紝application/octet-stream;charset=UTF-8閫氬父琛ㄧず鍝嶅簲鐨勫唴瀹规槸瀛楄妭娴侊紝
+            //骞朵笖瀛楃闆嗘槸UTF-8銆傚浜庤繖绉嶇被鍨嬬殑鍝嶅簲锛孲pring Boot榛樿浣跨敤ByteArrayHttpMessageConverter鏉ュ鐞嗭紝
+            //鍥犱负瀹冨彲浠ュ鐞嗘墍鏈塧pplication/octet-stream绫诲瀷鐨勫搷搴斻��
+            //鐒惰�岋紝ByteArrayHttpMessageConverter骞朵笉鐩存帴澶勭悊瀛楃闆嗭紙charset锛夈��
+            //瀛楃闆嗛�氬父鐢ㄤ簬鏂囨湰鍐呭锛岃�宎pplication/octet-stream閫氬父鐢ㄤ簬浜岃繘鍒跺唴瀹癸紝鍥犳鍦ㄨ繖绉嶆儏鍐典笅鎸囧畾瀛楃闆嗗彲鑳芥槸涓嶅悎閫傜殑銆�
+            //涓嶈繃锛屽鏋滀綘纭疄闇�瑕佸鐞嗗甫鏈夌壒瀹氬瓧绗﹂泦鐨刟pplication/octet-stream鍝嶅簲锛屼綘鍙兘闇�瑕佽嚜瀹氫箟HttpMessageConverter銆�
+            rep.addHeader("content-type", "application/octet-stream;charset=UTF-8");
+            rep.addHeader("Content-Disposition", "attachment;fileName=" + (rtuAddr + ".log")) ;
+            ServletOutputStream out = null;
+            FileInputStream in = null ;
+            try {
+                out = rep.getOutputStream() ;
+            } catch (Exception ee) {
+                out = null ;
+            }finally{
+                if(out != null){
+                    byte[] bs = new byte[1024] ;
+                    int len = -1 ;
+                    try {
+                        in = new FileInputStream(logFile);
+                        len = in.read(bs) ;
+                        while(len != -1){
+                            out.write(bs, 0, len);
+                            len = in.read(bs) ;
+                        }
+                    } catch (Exception eee) {
+                    } finally {
+                        if(out != null){
+                            try{
+                                out.flush();
+                                out.close();
+                            }catch(Exception e){
+                            }finally{
+                                if(in != null){
+                                    try{
+                                        in.close();
+                                    }catch(Exception e){
+                                    }
+                                }
+                            }
+                        }
+                    }
+                }
+            }
+        }
+    }
+    /**
+     * 涓嬭浇鎺у埗鍣紙RTU锛変笂涓嬭鏁版嵁鐨刲og鏃ュ織鏂囦欢
+     * @param rtuAddr
+     */
+    @GetMapping("/rtuLogText")
+    public BaseResponse<List<String>> rtuLogText(String rtuAddr){
+        List<String> list = new ArrayList() ;
+        File logFile = ResourceUnit.getInstance().getLogFile(rtuAddr + ".log") ;
+        if(logFile != null && logFile.exists()){
+            BufferedReader reader = null ;
+            try {
+                reader = new BufferedReader(new FileReader(logFile)) ;
+                String line ;
+                while((line = reader.readLine()) != null){
+                    list.add(line) ;
+                }
+                return BaseResponseUtils.buildSuccess(list);
+            } catch (Exception e) {
+                list.add("璇诲彇鎺у埗鍣紙" + rtuAddr + "锛夌殑鏃ュ織鏂囦欢寮傚父锛�" + (e.getMessage() == null?"":("锛�" + e.getMessage()))) ;
+                return BaseResponseUtils.buildSuccess(list);
+            }finally{
+                if(reader != null){
+                    try{
+                        reader.close();
+                    }catch(Exception e){
+                    }
+                }
+            }
+        }else{
+            list.add("鏈緱鍒版帶鍒跺櫒锛�" + rtuAddr + "锛夌殑鏃ュ織鏂囦欢") ;
+            return BaseResponseUtils.buildSuccess(list);
+        }
+    }
+    /**
+     * 鎺ユ敹web绯荤粺鍙戞潵鐨勫懡浠�
+     * @param com
+     * @return
+     */
     @PostMapping(path = "send", consumes = MediaType.APPLICATION_JSON_VALUE)
     public BaseResponse<Command> send(@RequestBody Command com) {
         log.info("鏀跺埌web绯荤粺鍙戞潵鐨勫懡浠わ細\n" + com.toString()) ;

--
Gitblit v1.8.0