From 19b7530c7feb8eca1dfecd6502feaf61057fdab8 Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期三, 05 二月 2025 15:04:37 +0800
Subject: [PATCH] 修改字段大小写

---
 ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/drainage/TCECUtil.java |   88 +++++++++++++++++++++++++++-----------------
 1 files changed, 54 insertions(+), 34 deletions(-)

diff --git a/ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/drainage/TCECUtil.java b/ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/drainage/TCECUtil.java
index 397691b..b3e724e 100644
--- a/ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/drainage/TCECUtil.java
+++ b/ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/drainage/TCECUtil.java
@@ -28,24 +28,20 @@
  */
 @Slf4j
 public class TCECUtil {
-	/**
-	 * 运营商标识
-	 */
-	private static final String OperatorID = "";
 	
-	private static OperatorClient operatorClient = SpringUtils.getBean(OperatorClient.class);
+//	private static OperatorClient operatorClient = SpringUtils.getBean(OperatorClient.class);
 	
-	private static Map<Long, Integer> map = new HashMap<>();
+	public static Map<Long, Integer> map = new HashMap<>();
 	
 	
 	/**
 	 * 获取token
 	 */
 	public static String queryToken(Operator operator){
-		HttpRequest post = HttpUtil.createPost("");
+		HttpRequest post = HttpUtil.createPost(operator.getTestUrl() + InterfaceUrlEnum.QUERY_TOKEN.getUrl());
 		post.contentType("application/json;charset=utf-8");
 		JSONObject body = new JSONObject();
-		body.put("OperatorID", OperatorID);
+		body.put("OperatorID", operator.getOurOperatorId());
 		body.put("OperatorSecret", operator.getOurOperatorSecret());
 		post.body(body.toJSONString());
 		HttpResponse execute = post.execute();
@@ -64,7 +60,7 @@
 		LocalDateTime localDateTime = Instant.ofEpochSecond(tokenAvailableTime).atOffset(ZoneOffset.UTC).toLocalDateTime();
 		operator.setAccessToken(token);
 		operator.setTokenAvailableTime(localDateTime);
-		operatorClient.editOperator(operator);
+//		operatorClient.editOperator(operator);
 		return token;
 	}
 	
@@ -99,28 +95,6 @@
 	}
 	
 	
-	/**
-	 * 站点变更通知
-	 * @param operator
-	 * @param type
-	 * @param siteIds
-	 * @return
-	 */
-	public static NotificationStationChangeResult notificationStationChange(Operator operator, Integer type, List<Integer> siteIds) {
-		StationChange stationChange = new StationChange();
-		stationChange.setOperatorId(OperatorID);
-		stationChange.setType(type);
-		List<String> collect = siteIds.stream().map(String::valueOf).collect(Collectors.toList());
-		stationChange.setStationIds(collect);
-		HttpRequest post = HttpUtil.createPost(operator.getTestUrl() + InterfaceUrlEnum.NOTIFICATION_STATION_CHANGE.getUrl());
-		buildBody(post, stationChange, operator);
-		HttpResponse execute = post.execute();
-		if(200 != execute.getStatus()){
-			log.error("推送站点变更通知失败:" + execute.body());
-			return null;
-		}
-		return JSON.parseObject(execute.body(), NotificationStationChangeResult.class);
-	}
 	
 	
 	
@@ -241,14 +215,14 @@
 		post.contentType("application/json;charset=utf-8");
 		post.header("Authorization", "Bearer " + getToken(operator));
 		BaseRequest baseRequest = new BaseRequest();
-		baseRequest.setOperatorID(OperatorID);
+		baseRequest.setOperatorID(operator.getOurOperatorId());
 		baseRequest.setTimeStamp(timeStamp);
 		baseRequest.setSeq(String.format("%04d", integer));
 		String jsonString = JSON.toJSONString(o);
-		String encrypt = AESUtil.encrypt(jsonString, operator.getDataSecret(), operator.getDataSecretIv());
+		String encrypt = AESUtil.encrypt(jsonString, operator.getOurDataSecret(), operator.getOurDataSecretIv());
 		baseRequest.setData(encrypt);
 		baseRequest.setOperator(operator);
-		baseRequest.setSig(buildSign(baseRequest));
+		baseRequest.setSig(ourBuildSign(baseRequest));
 		post.body(JSON.toJSONString(baseRequest));
 		//清空小于当前时间的map中的无效数据
 		for (Long k : map.keySet()) {
@@ -284,4 +258,50 @@
 		return sign;
 	}
 	
+	
+	
+	/**
+	 * 构建签名字符串
+	 * @param model
+	 * @return
+	 */
+	public static String ourBuildSign(BaseModel model){
+		Operator operator = model.getOperator();
+		//签名秘钥SigSecret
+		String key = operator.getOurSigSecret();
+		String sign = "";
+		switch (operator.getName()){
+			case "XinDianTu":
+				//进行字符串拼接、计算
+				String m = new StringBuilder(operator.getOurOperatorId()).append(model.getData()).append(model.getTimeStamp()).append(model.getSeq()).toString();
+				byte[] hmacMd5 = SignUtil.getHMacMD5Bytes(key.getBytes(), m.getBytes());
+				// 打印计算得到的签名Sig
+				sign = SignUtil.bytesToHexString(hmacMd5);
+				break;
+			case "KuaiDian":
+				sign = SignUtil.hmacSign(model.getData(), key);
+				break;
+		}
+		return sign;
+	}
+	
+	
+	public static void main(String[] args) {
+		BaseModel model = new BaseModel();
+		model.setOperatorID("MA25CNM38");
+		model.setData("lkQUXmphG3h5Wf0UIxSfzNoCdqDLYkmDGceCbofJuWFqKBwCYulTUHSn9bJpVMVFNji/4xtSq3o1U5jSZZwIhA==");
+		model.setTimeStamp(20250205120800L);
+		model.setSeq("0001");
+		Operator operator = new Operator();
+		operator.setName("XinDianTu");
+		operator.setSigSecret("S94xUpTpOIlLJBk8");
+		model.setOperator(operator);
+		String key = operator.getSigSecret();
+		
+		String m = new StringBuilder(model.getOperatorID()).append(model.getData()).append(model.getTimeStamp()).append(model.getSeq()).toString();
+		byte[] hmacMd5 = SignUtil.getHMacMD5Bytes(key.getBytes(), m.getBytes());
+		// 打印计算得到的签名Sig
+		String s = SignUtil.bytesToHexString(hmacMd5);
+		System.err.println(s);
+	}
 }

--
Gitblit v1.7.1