From 37d2aec0dbe914c8924d6514da7eca053eee4cf3 Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期三, 26 三月 2025 17:26:35 +0800
Subject: [PATCH] Merge branch 'master' of http://8.140.179.55:20000/r/pipIrr-SV

---
 pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu3rd/src/main/java/com/dy/rtuMw3rd/http4Xjnk/HttpRq.java                                |  228 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 pipIrr-platform/pipIrr-web/pipIrr-mwTest-web/src/main/java/com/dy/pipIrrMwTestWeb/p206V202404test/CommandP206V202404Ctrl.java |    4 
 pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/Cd_92_A2_Down.java                    |    2 
 pipIrr-platform/pipIrr-mw/pom.xml                                                                                             |    1 
 4 files changed, 231 insertions(+), 4 deletions(-)

diff --git a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/Cd_92_A2_Down.java b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/Cd_92_A2_Down.java
index c767292..a67201e 100644
--- a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/Cd_92_A2_Down.java
+++ b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/Cd_92_A2_Down.java
@@ -121,7 +121,7 @@
             if(cvo.moneyRemain == null){
                 cvo.moneyRemain = 0.0 ;
             }
-            strTemp = "" + (Double.valueOf(cvo.moneyRemain * 100)).intValue() ;
+            strTemp = "" + (Double.valueOf(cvo.moneyRemain * 10000)).intValue() ;
             bTemp = ByteUtil.string2BCD_LE(strTemp) ;
             bTempLen = bTemp.length ;
             count = 0 ;
diff --git a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu3rd/src/main/java/com/dy/rtuMw3rd/http4Xjnk/HttpRq.java b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu3rd/src/main/java/com/dy/rtuMw3rd/http4Xjnk/HttpRq.java
new file mode 100644
index 0000000..0343a3f
--- /dev/null
+++ b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu3rd/src/main/java/com/dy/rtuMw3rd/http4Xjnk/HttpRq.java
@@ -0,0 +1,228 @@
+package com.dy.rtuMw3rd.http4Xjnk;
+
+import com.dy.common.util.HttpCallback;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.*;
+import org.springframework.http.converter.StringHttpMessageConverter;
+import org.springframework.http.converter.json.MappingJackson2HttpMessageConverter;
+import org.springframework.stereotype.Component;
+import org.springframework.web.client.RestTemplate;
+import org.springframework.web.util.UriComponentsBuilder;
+
+import java.nio.charset.StandardCharsets;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.concurrent.CompletableFuture;
+
+/**
+ * @Author: liurunyu
+ * @Date: 2025/3/15 9:56
+ * @Description
+ */
+@Component()
+public class HttpRq {
+
+    private RestTemplate restTemplate ;
+
+    @Autowired
+    public void setRestTemplate(RestTemplate restTemplate){
+        this.restTemplate = restTemplate;
+    }
+
+    /**
+     * get璇锋眰锛岃繑鍥瀓son鍐呭
+     * 鍚屾
+     * @param httpBaseUrl
+     * @param params
+     * @param cb
+     * @throws Exception
+     */
+    public void get4JsonBySync(String httpBaseUrl, Map<String, String> params, HttpCallback cb) throws Exception {
+        String url = UriComponentsBuilder.fromUriString(httpBaseUrl)
+                .build()
+                .toUriString();
+
+        UriComponentsBuilder builder = UriComponentsBuilder.fromHttpUrl(url) ;
+        if(params != null && params.size() > 0){
+            Iterator<String> it = params.keySet().iterator() ;
+            String key ;
+            while (it.hasNext()){
+                key = it.next() ;
+                builder.queryParam(key, params.get(key)) ;
+            }
+        }
+        httpGetRequestSync(builder, cb);
+    }
+    /**
+     * get璇锋眰锛岃繑鍥瀓son鍐呭
+     * 寮傛
+     * @param httpBaseUrl
+     * @param params
+     * @param cb
+     * @throws Exception
+     */
+    public void get4JsonByAsync(String httpBaseUrl, Map<String, String> params, HttpCallback cb) throws Exception {
+        String url = UriComponentsBuilder.fromUriString(httpBaseUrl)
+                .build()
+                .toUriString();
+
+        UriComponentsBuilder builder = UriComponentsBuilder.fromHttpUrl(url) ;
+        if(params != null && params.size() > 0){
+            Iterator<String> it = params.keySet().iterator() ;
+            String key ;
+            while (it.hasNext()){
+                key = it.next() ;
+                builder.queryParam(key, params.get(key)) ;
+            }
+        }
+        httpGetRequestAsync(builder, cb);
+    }
+
+    /**
+     * get璇锋眰锛岃繑鍥瀓son鍐呭
+     * 鍚屾
+     * @param httpBaseUrl
+     * @param params
+     * @param cb
+     * @throws Exception
+     */
+    public void post4JsonBySync(String httpBaseUrl, Map<String, String> params, HttpCallback cb) throws Exception {
+        String url = UriComponentsBuilder.fromUriString(httpBaseUrl)
+                .build()
+                .toUriString();
+
+        UriComponentsBuilder builder = UriComponentsBuilder.fromHttpUrl(url) ;
+        httpPostRequestSync(builder, params, cb);
+    }
+    /**
+     * get璇锋眰锛岃繑鍥瀓son鍐呭
+     * 寮傛
+     * @param httpBaseUrl
+     * @param params
+     * @param cb
+     * @throws Exception
+     */
+    public void post4JsonByAsync(String httpBaseUrl, Map<String, String> params, HttpCallback cb) throws Exception {
+        String url = UriComponentsBuilder.fromUriString(httpBaseUrl)
+                .build()
+                .toUriString();
+
+        UriComponentsBuilder builder = UriComponentsBuilder.fromHttpUrl(url) ;
+        httpPostRequestAsync(builder, params, cb);
+    }
+
+    /**
+     * 鍙戣捣璇锋眰
+     * @param builder
+     * @param cb
+     * @return
+     */
+    private void httpGetRequestSync(UriComponentsBuilder builder, HttpCallback cb) {
+        HttpHeaders headers = new HttpHeaders() ;
+        headers.setContentType(MediaType.APPLICATION_JSON) ;
+        restTemplate.getMessageConverters().set(1,new StringHttpMessageConverter(StandardCharsets.UTF_8));
+        // 閫氳繃Get鏂瑰紡璋冪敤鎺ュ彛
+        ResponseEntity<String> response = restTemplate.exchange(builder.toUriString(),
+                HttpMethod.GET,
+                new HttpEntity<>(headers),
+                String.class);
+
+        String contentType = response.getHeaders().getContentType().toString() ;
+        cb.call(response.getStatusCode().value() + "", contentType, response.getBody());
+    }
+
+
+    /**
+     * 鍙戣捣璇锋眰
+     * @param builder
+     * @param cb
+     * @return
+     */
+    private void httpGetRequestAsync(UriComponentsBuilder builder, HttpCallback cb) throws Exception {
+        HttpHeaders headers = new HttpHeaders() ;
+        headers.setContentType(MediaType.APPLICATION_JSON) ;
+        restTemplate.getMessageConverters().set(1,new StringHttpMessageConverter(StandardCharsets.UTF_8));
+        // 鍙戣捣寮傛 GET 璇锋眰
+        CompletableFuture<ResponseEntity<String>> future = CompletableFuture.supplyAsync(() ->
+                // 閫氳繃Get鏂瑰紡璋冪敤鎺ュ彛
+                restTemplate.exchange(builder.toUriString(),
+                        HttpMethod.GET,
+                        new HttpEntity<>(headers),
+                        String.class)
+        );
+        future.thenAccept(response -> {
+            String contentType = response.getHeaders().getContentType().toString() ;
+            cb.call(response.getStatusCode().value() + "", contentType, response.getBody());
+        }) ;
+        /*
+        AtomicReference<Throwable> exeEx = new AtomicReference() ;
+        future.thenAccept(response -> {
+            String contentType = response.getHeaders().getContentType().toString() ;
+            cb.call(response.getStatusCode().value() + "", contentType, response.getBody());
+        }).exceptionally(ex -> {
+            exeEx.set(ex.getCause());
+            return null;
+        });
+        */
+    }
+
+    /**
+     * 鍙戣捣璇锋眰
+     * @param builder
+     * @param body
+     * @param cb
+     * @return
+     */
+    private void httpPostRequestSync(UriComponentsBuilder builder, Map<String, String> body, HttpCallback cb) {
+        HttpHeaders headers = new HttpHeaders() ;
+        headers.setContentType(MediaType.APPLICATION_JSON) ;
+        restTemplate.getMessageConverters().set(1,new StringHttpMessageConverter(StandardCharsets.UTF_8));
+        restTemplate.getMessageConverters().add(new MappingJackson2HttpMessageConverter());
+        HttpEntity<Map<String, String>> requestEntity = new HttpEntity<>(body, headers);
+        // 閫氳繃Get鏂瑰紡璋冪敤鎺ュ彛
+        ResponseEntity<String> response = restTemplate.exchange(builder.toUriString(),
+                HttpMethod.POST,
+                requestEntity,
+                String.class);
+
+        String contentType = response.getHeaders().getContentType().toString() ;
+        cb.call(response.getStatusCode().value() + "", contentType, response.getBody());
+    }
+
+    /**
+     * 鍙戣捣璇锋眰
+     * @param builder
+     * @param body
+     * @param cb
+     * @return
+     */
+    private void httpPostRequestAsync(UriComponentsBuilder builder, Map<String, String> body, HttpCallback cb) throws Exception {
+        HttpHeaders headers = new HttpHeaders() ;
+        headers.setContentType(MediaType.APPLICATION_JSON) ;
+        restTemplate.getMessageConverters().set(1,new StringHttpMessageConverter(StandardCharsets.UTF_8));
+        restTemplate.getMessageConverters().add(new MappingJackson2HttpMessageConverter());
+        HttpEntity<Map<String, String>> requestEntity = new HttpEntity<>(body, headers);
+        // 鍙戣捣寮傛 GET 璇锋眰
+        CompletableFuture<ResponseEntity<String>> future = CompletableFuture.supplyAsync(() ->
+                // 閫氳繃Get鏂瑰紡璋冪敤鎺ュ彛
+                restTemplate.exchange(builder.toUriString(),
+                        HttpMethod.POST,
+                        requestEntity,
+                        String.class)
+        );
+        future.thenAccept(response -> {
+            String contentType = response.getHeaders().getContentType().toString() ;
+            cb.call(response.getStatusCode().value() + "", contentType, response.getBody());
+        }) ;
+        /*
+        AtomicReference<Throwable> exeEx = new AtomicReference() ;
+        future.thenAccept(response -> {
+            String contentType = response.getHeaders().getContentType().toString() ;
+            cb.call(response.getStatusCode().value() + "", contentType, response.getBody());
+        }).exceptionally(ex -> {
+            exeEx.set(ex.getCause());
+            return null;
+        });
+        */
+    }
+}
diff --git a/pipIrr-platform/pipIrr-mw/pom.xml b/pipIrr-platform/pipIrr-mw/pom.xml
index 3e0de09..69e82be 100644
--- a/pipIrr-platform/pipIrr-mw/pom.xml
+++ b/pipIrr-platform/pipIrr-mw/pom.xml
@@ -21,7 +21,6 @@
         <module>pipIrr-mw-simulate-rtu202404</module>
         <module>pipIrr-mwTest-server</module>
         <module>pipIrr-mwTest-client</module>
-        <module>pipIrr-mw-rtu3rdTest</module>
     </modules>
 
     <dependencies>
diff --git a/pipIrr-platform/pipIrr-web/pipIrr-mwTest-web/src/main/java/com/dy/pipIrrMwTestWeb/p206V202404test/CommandP206V202404Ctrl.java b/pipIrr-platform/pipIrr-web/pipIrr-mwTest-web/src/main/java/com/dy/pipIrrMwTestWeb/p206V202404test/CommandP206V202404Ctrl.java
index 28fa373..e6715af 100644
--- a/pipIrr-platform/pipIrr-web/pipIrr-mwTest-web/src/main/java/com/dy/pipIrrMwTestWeb/p206V202404test/CommandP206V202404Ctrl.java
+++ b/pipIrr-platform/pipIrr-web/pipIrr-mwTest-web/src/main/java/com/dy/pipIrrMwTestWeb/p206V202404test/CommandP206V202404Ctrl.java
@@ -218,8 +218,8 @@
         comVo.projectNo = CommandP206V202404Ctrl.projectNo  ;
         //comVo.icCardAddr = Test.icCardAddr ;//IC鍗″湴鍧�(8浣嶆暟瀛楁垨瀛楁瘝)
         comVo.icCardNo = CommandP206V202404Ctrl.icCardNo ;//鐢ㄦ埛鍗″簭鍒楀彿锛�17浣嶆暟瀛楋級锛�6瀛楄妭BCD锛�2瀛楄妭HEX锛�
-        comVo.waterRemain = 123.45 ;//鍗曚綅:鍏�  2浣嶅皬鏁扮偣(鏈�澶у�� 99999999.99)
-        comVo.moneyRemain = 234.56 ;//鍗曚綅:m3  2浣嶅皬鏁扮偣(鏈�澶у�� 99999999.99)
+        comVo.waterRemain = 123.45 ;//鍗曚綅:m3  2浣嶅皬鏁扮偣(鏈�澶у�� 99999999.99)
+        comVo.moneyRemain = 12345.67 ;//鍗曚綅:鍏�  2浣嶅皬鏁扮偣(鏈�澶у�� 99999999.99)
         comVo.waterPrice = 0.8 ;//姘撮噺鍗曚环 鍗曚綅:鍏�, 2涓皬鏁扮偣
         comVo.elePrice = 1.2 ;//鐢甸噺鍗曚环 鍗曚綅:鍏�, 2涓皬鏁扮偣
         comVo.orderNo = "1234567890123456" ;//璁㈠崟鍙凤紙16浣嶆暟瀛楋級

--
Gitblit v1.8.0