From 70aeac289c132085e91d59dc82bc1facd41889fa Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期一, 24 二月 2025 15:33:53 +0800
Subject: [PATCH] 有关表阀一体机(王江海制定)通信协议: 1、根据新版本协议,解析部分更新; 2、根据测试一体阀协议数据处理需求与逻辑,进行表阀一体机数据处理。
---
 pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/client/ClientCtrl.java |  230 ++++-----------------------------------------------------
 1 files changed, 17 insertions(+), 213 deletions(-)
diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/client/ClientCtrl.java b/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/client/ClientCtrl.java
index 7d16dba..5e5e66c 100644
--- a/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/client/ClientCtrl.java
+++ b/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/client/ClientCtrl.java
@@ -1,8 +1,5 @@
 package com.dy.pipIrrSell.client;
 
-import com.alibaba.fastjson2.JSONObject;
-import com.aliyuncs.dysmsapi.model.v20170525.SendSmsResponse;
-import com.aliyuncs.exceptions.ClientException;
 import com.dy.common.aop.SsoAop;
 import com.dy.common.webUtil.BaseResponse;
 import com.dy.common.webUtil.BaseResponseUtils;
@@ -10,16 +7,7 @@
 import com.dy.common.webUtil.ResultCodeMsg;
 import com.dy.pipIrrGlobal.pojoBa.BaClient;
 import com.dy.pipIrrGlobal.pojoSe.SeClient;
-import com.dy.pipIrrGlobal.pojoSe.SeCodeVerify;
-import com.dy.pipIrrGlobal.pojoSe.SeOpenId;
 import com.dy.pipIrrGlobal.voSe.VoClient;
-import com.dy.pipIrrGlobal.voSe.VoClientWechat;
-import com.dy.pipIrrSell.client.dto.CodeVerifyDTO;
-import com.dy.pipIrrSell.result.SellResultCode;
-import com.dy.pipIrrSell.sms.AliyunSmsSv;
-import com.dy.pipIrrSell.sms.RandomCode;
-import com.dy.pipIrrSell.util.RestTemplateUtil;
-import com.dy.pipIrrSell.wechatpay.PayInfo;
 import io.swagger.v3.oas.annotations.Operation;
 import io.swagger.v3.oas.annotations.media.Content;
 import io.swagger.v3.oas.annotations.media.Schema;
@@ -30,12 +18,12 @@
 import jakarta.validation.constraints.NotNull;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.factory.annotation.Value;
 import org.springframework.http.MediaType;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.validation.BindingResult;
 import org.springframework.web.bind.annotation.*;
 
-import java.io.IOException;
 import java.util.*;
 
 /**
@@ -52,20 +40,9 @@
 @RequiredArgsConstructor
 public class ClientCtrl {
     private final ClientSv clientSv;
-    private final AliyunSmsSv aliyunSmsSv;
     //private final RedisUtils redisUtils;
-    private final RestTemplateUtil restTemplateUtil;
-
-    private final String privateCertFileName = PayInfo.privateCertFileName;
-    private final String appid = PayInfo.appid;
-    private final String secret = PayInfo.secret;
-    private final String mchid = PayInfo.mchid;
-    private final String schema = PayInfo.schema;
-    private final String signType = PayInfo.signType;
-    private final String description = PayInfo.description;
-    private final String loginUrl = PayInfo.loginUrl;
-    private final String notifyUrl = PayInfo.notifyUrl;
-    private final String grantType = PayInfo.grantType;
+    @Value("${project.projectNo}")
+    private Integer projectNo;
 
     /**
      * 鑾峰彇鍐滄埛鍒楄〃
@@ -166,9 +143,12 @@
         String villageName = map_districts.get("villageName").toString();
 
         // 鐢熸垚8浣嶈鏀垮尯鍒掔紪鐮侊紝鐢熸垚鍐滄埛缂栧彿鐢�
-        String district8 = countyNum + townNum + villageNum;
+        String district8 = String.format("%02d", Integer.parseInt(countyNum))  + String.format("%03d", Integer.parseInt(townNum)) + String.format("%03d", Integer.parseInt(villageNum));
         // 鐢熸垚鍐滄埛缂栧彿
         String clientNum = generateClientNum(district8);
+        if(clientNum == null) {
+            return BaseResponseUtils.buildErrorMsg("鍐滄埛缂栧彿瓒呴檺");
+        }
         // 鐢熸垚12浣�5绾ц鏀垮尯鍒掔紪鐮佷覆鍙婂悕绉颁覆
         Long districtNum = Long.parseLong(provinceNum + cityNum + district8);
         String districtTitle = countryName + townName + villageName;
@@ -221,7 +201,7 @@
             Integer number = Integer.parseInt(clientNum.substring(8));
             number = number + 1;
             if(number > 9999) {
-                return "鍐滄埛缂栧彿瓒呴檺";
+                return null;
             }
             clientNum = clientNum.substring(0, 8) + String.format("%04d", number);
         } else {
@@ -276,7 +256,8 @@
         String villageName = map_districts.get("villageName").toString();
 
         // 鐢熸垚8浣嶈鏀垮尯鍒掔紪鐮侊紝鐢熸垚鍐滄埛缂栧彿鐢�
-        String district8 = countyNum + townNum + villageNum;
+        //String district8 = countyNum + townNum + villageNum;
+        String district8 = String.format("%02d", Integer.parseInt(countyNum))  + String.format("%03d", Integer.parseInt(townNum)) + String.format("%03d", Integer.parseInt(villageNum));
         // 鐢熸垚鍐滄埛缂栧彿
         String clientNum = generateClientNum(district8);
         // 鐢熸垚12浣�5绾ц鏀垮尯鍒掔紪鐮佷覆鍙婂悕绉颁覆
@@ -387,13 +368,13 @@
         // 鐢熸垚12浣�5绾ц鏀垮尯鍒掔紪鐮佷覆鍙婂悕绉颁覆
         Long districtNum = Long.parseLong(provinceNum + cityNum + countyNum + townNum + villageNum);
         //鑾峰彇椤圭洰缂栫爜
-        String projectNo = clientSv.getItemValue("projectNo");
-        //杞负int
-        Integer projectNo1 = Integer.valueOf(projectNo);
-        //杞负16杩涘埗
-//        String projectNo2 = Integer.toHexString(projectNo1);
-//        log.info(projectNo2);
-        String projectNo3 = String.format("%02x", projectNo1);
+//        String projectNo = clientSv.getItemValue("projectNo");
+//        //杞负int
+//        Integer projectNo1 = Integer.valueOf(projectNo);
+//        //杞负16杩涘埗
+////        String projectNo2 = Integer.toHexString(projectNo1);
+////        log.info(projectNo2);
+        String projectNo3 = String.format("%02x", projectNo);
         log.info(projectNo3);
 
         Map map = new HashMap();
@@ -401,181 +382,4 @@
         map.put("projectNo",projectNo3);
         return BaseResponseUtils.buildSuccess(map);
     }
-
-    /**
-     * 鍙戦�侀獙璇佺爜
-     * @param phoneNumber
-     * @return
-     */
-    @Operation(summary = "鍙戦�侀獙璇佺爜", description = "鍙戦�侀獙璇佺爜")
-    @ApiResponses(value = {
-            @ApiResponse(
-                    responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE,
-                    description = "鎿嶄綔缁撴灉锛歵rue锛氭垚鍔燂紝false锛氬け璐ワ紙BaseResponse.content锛�",
-                    content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE,
-                            schema = @Schema(implementation = Boolean.class))}
-            )
-    })
-    @PostMapping(path = "send_sms")
-    @SsoAop()
-    public BaseResponse<Boolean> sendSms(@RequestParam(name = "phoneNumber", required = true) String phoneNumber) throws ClientException {
-        if(phoneNumber == null || phoneNumber.length() <= 0) {
-            return BaseResponseUtils.buildFail(SellResultCode.PHONE_NUMBER_CANNOT_BE_NULL.getMessage());
-        }
-
-        // 鐢熸垚6浣嶉獙璇佺爜骞惰浆涓篔son鏍煎紡
-        String securityCode = String.valueOf(RandomCode.genCode());
-        JSONObject param = new JSONObject();
-        param.put("code", securityCode);
-        String templateParam = param.toJSONString();
-
-        //redisUtils.set(phoneNumber, securityCode, 60);
-
-        // 鑾峰彇褰撳墠鏃堕棿鎴冲苟寤跺悗3鍒嗛挓
-        Long timestamp = System.currentTimeMillis();
-        Calendar calendar = Calendar.getInstance();
-        calendar.setTimeInMillis(timestamp);
-        calendar.add(Calendar.SECOND, 180);
-        Long expires = calendar.getTimeInMillis();
-
-        SeCodeVerify codeVerify = new SeCodeVerify();
-        codeVerify.setPhoneNumber(phoneNumber);
-        codeVerify.setSecurityCode(securityCode);
-        codeVerify.setExpires(expires);
-        clientSv.addCodeVerify(codeVerify);
-
-        SendSmsResponse response = aliyunSmsSv.sendSms(phoneNumber, templateParam);
-        if (response.getCode().equals("OK")) {
-            // 鍙戦�佹垚鍔熷鐞嗛�昏緫
-            return BaseResponseUtils.buildSuccess(true) ;
-        } else {
-            // 鍙戦�佸け璐ュ鐞嗛�昏緫
-            return BaseResponseUtils.buildFail(SellResultCode.SECURITY_CODE_SEND_FAIL.getMessage()) ;
-        }
-    }
-
-    /**
-     * 鏍¢獙楠岃瘉鐮�
-     * @param po
-     * @param bindingResult
-     * @return
-     * @throws IOException
-     */
-    @Operation(summary = "鏍¢獙楠岃瘉鐮�", description = "鏍¢獙楠岃瘉鐮�")
-    @ApiResponses(value = {
-            @ApiResponse(
-                    responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE,
-                    description = "鎿嶄綔缁撴灉锛歵rue锛氭垚鍔燂紝false锛氬け璐ワ紙BaseResponse.content锛�",
-                    content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE,
-                            schema = @Schema(implementation = Boolean.class))}
-            )
-    })
-    @PostMapping(path = "verify", consumes = MediaType.APPLICATION_JSON_VALUE)
-    @Transactional(rollbackFor = Exception.class)
-    @SsoAop()
-    public BaseResponse<Boolean> verify(@RequestBody @Valid CodeVerifyDTO po, BindingResult bindingResult) throws IOException {
-        if(bindingResult != null && bindingResult.hasErrors()){
-            return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage());
-        }
-
-        String phoneNumber = po.getPhoneNumber();
-        String securityCode = po.getSecurityCode();
-        String code = po.getCode();
-
-        // 杩涜鎵嬫満鍙枫�侀獙璇佺爜銆佽繃鏈熸椂闂存牎楠�
-        SeCodeVerify codeVerify = clientSv.getCodeVerify(phoneNumber);
-        if(codeVerify == null) {
-            return BaseResponseUtils.buildFail(SellResultCode.NO_SECURITY_CODE_FOR_PHONE.getMessage());
-        }
-
-        if(!codeVerify.getSecurityCode().equals(securityCode)) {
-            return BaseResponseUtils.buildFail(SellResultCode.SECURITY_CODE_ERROR.getMessage());
-        }
-
-        Long currentTimestamp = System.currentTimeMillis();
-        if(currentTimestamp > codeVerify.getExpires() ) {
-            return BaseResponseUtils.buildFail(SellResultCode.VALIDATION_TIMEOUT.getMessage());
-        }
-
-        // 鏍¢獙閫氳繃锛岃繘琛岀櫥褰曞嚟璇佹牎楠�
-        Map<String, Object> queryParams = new HashMap<>();
-        queryParams.put("appid", appid);
-        queryParams.put("secret", secret);
-        queryParams.put("js_code", code);
-        queryParams.put("grant_type", grantType);
-        Map<String, String> headerParams = new HashMap<>();
-        JSONObject job = restTemplateUtil.get(loginUrl, queryParams, headerParams);
-
-        if(job.getLong("errcode") != null && job.getLong("errcode") >= -1) {
-            return BaseResponseUtils.buildFail("鐧诲綍鍑瘉鏍¢獙澶辫触");
-        }
-        String openid = job.getString("openid");
-        String sessionKey = job.getString("session_key");
-
-        Long clientId = clientSv.getClientIdByPhone(phoneNumber);
-        if(clientId != null) {
-            // 娣诲姞寰俊鐢ㄦ埛璐︽埛璁板綍
-            SeOpenId seOpenId = new SeOpenId();
-            seOpenId.setClientId(clientId);
-            seOpenId.setOpenId(openid);
-            seOpenId.setSessionKey(sessionKey);
-            seOpenId.setCreateTime(new Date());
-            Long SessionId = clientSv.addOpenId(seOpenId);
-            return BaseResponseUtils.buildSuccess(SessionId);
-
-        } else {
-            return BaseResponseUtils.buildError(SellResultCode.PHONE_NUMBER_IS_ERROR.getMessage());
-        }
-    }
-
-    /**
-     * 鑾峰彇鍐滄埛鍩烘湰淇℃伅锛屽皬绋嬪簭棣栭〉浣跨敤
-     * @param sessionId
-     * @return
-     */
-    @GetMapping(path = "/simple_info")
-    @SsoAop()
-    public BaseResponse<VoClientWechat> getSimpleClientInfo(@RequestParam Long sessionId){
-        try {
-            VoClientWechat res = clientSv.getSimpleClientInfo(sessionId, null);
-            return BaseResponseUtils.buildSuccess(res);
-        } catch (Exception e) {
-            log.error("鏌ヨ鍐滄埛寮傚父", e);
-            return BaseResponseUtils.buildException(e.getMessage()) ;
-        }
-    }
-
-    /**
-     * 鐧诲綍鍑瘉鐧诲綍
-     * @param code 涓存椂鐧诲綍鍑瘉
-     * @return
-     */
-    @GetMapping(path = "/code_login")
-    @SsoAop()
-    public BaseResponse<VoClientWechat> codeLogin(@RequestParam String code) throws IOException {
-
-        // 鐧诲綍鍑瘉鏍¢獙
-        Map<String, Object> queryParams = new HashMap<>();
-        queryParams.put("appid", appid);
-        queryParams.put("secret", secret);
-        queryParams.put("js_code", code);
-        queryParams.put("grant_type", grantType);
-        Map<String, String> headerParams = new HashMap<>();
-        JSONObject job = restTemplateUtil.get(loginUrl, queryParams, headerParams);
-
-        String openId = job.getString("openid");
-        if(openId == null) {
-            return BaseResponseUtils.buildFail(SellResultCode.LOGIN_FAIL.getMessage());
-        }
-
-        try {
-            VoClientWechat res = clientSv.getSimpleClientInfo(null, openId);
-            return BaseResponseUtils.buildSuccess(res);
-        } catch (Exception e) {
-            log.error("鏌ヨ鍐滄埛寮傚父", e);
-            return BaseResponseUtils.buildException(e.getMessage()) ;
-        }
-    }
-
-
 }
--
Gitblit v1.8.0