From 658e843113e09d1bf319a29e40a17a2d11ffabab Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Tue, 06 Aug 2024 00:05:49 +0800
Subject: [PATCH] 1
---
geteClient/src/main/java/org/example/geteclient/wsClinet/GateClient.java | 45 +++++++++++++++++++++++----------------------
1 files changed, 23 insertions(+), 22 deletions(-)
diff --git a/geteClient/src/main/java/org/example/geteclient/wsClinet/GateClient.java b/geteClient/src/main/java/org/example/geteclient/wsClinet/GateClient.java
index 7ef4318..cf395ba 100644
--- a/geteClient/src/main/java/org/example/geteclient/wsClinet/GateClient.java
+++ b/geteClient/src/main/java/org/example/geteclient/wsClinet/GateClient.java
@@ -92,8 +92,6 @@
private static final String RESULT_KEY = "result"; // 定义结果键的常量
private static final String BIDS_KEY = "bids"; // 定义 bids 的常量
private static final String ASKS_KEY = "asks"; // 定义 asks 的常量
- private static final String p = "p"; // 定义 asks 的常量
- private static final String v = "v"; // 定义 asks 的常量
private static final String S_KEY = "s"; // 定义 s 的常量
@OnMessage
@@ -110,28 +108,30 @@
Object asksObj = resultMap.get(BIDS_KEY);
Object bidsObj = resultMap.get(ASKS_KEY);
- if (asksObj instanceof List && !((List<?>) asksObj).isEmpty()) {
- List<?> asksList = (List<?>) asksObj;
- String[][] dataArray = gson.fromJson(gson.toJson(asksList), String[][].class);
- HashMap<String, Object> pvMap = new HashMap<>(); // 创建新的 HashMap 保存 bids 和 asks
- String[] asksData = dataArray[0];
- pvMap.put(p, new BigDecimal(asksData[0]));
- pvMap.put(v, new BigDecimal(asksData[1]));
- hashMap.put(BIDS_KEY, pvMap); // 放入 bids 数据
- }
+ if(asksObj instanceof List && !((List<?>) asksObj).isEmpty() && bidsObj instanceof List && !((List<?>) bidsObj).isEmpty()){
+ if (asksObj instanceof List && !((List<?>) asksObj).isEmpty()) {
+ List<?> asksList = (List<?>) asksObj;
+ String[][] dataArray = gson.fromJson(gson.toJson(asksList), String[][].class);
+ HashMap<String, Object> pvMap = new HashMap<>(); // 创建新的 HashMap 保存 bids 和 asks
+ String[] asksData = dataArray[0];
+ pvMap.put("p", new BigDecimal(asksData[0]).toPlainString());
+ pvMap.put("v", new BigDecimal(asksData[1]).toPlainString());
+ hashMap.put(BIDS_KEY, pvMap); // 放入 bids 数据
+ }
- if (bidsObj instanceof List && !((List<?>) bidsObj).isEmpty()) {
- List<?> bidsList = (List<?>) bidsObj;
- String[][] dataArray = gson.fromJson(gson.toJson(bidsList), String[][].class);
- String[] bidsData = dataArray[0];
- HashMap<String, Object> pvMap = new HashMap<>(); // 创建新的 HashMap 保存 bids 和 asks
- pvMap.put(p, new BigDecimal(bidsData[0]));
- pvMap.put(v, new BigDecimal(bidsData[1]));
- hashMap.put(ASKS_KEY,pvMap);
- }
+ if (bidsObj instanceof List && !((List<?>) bidsObj).isEmpty()) {
+ List<?> bidsList = (List<?>) bidsObj;
+ String[][] dataArray = gson.fromJson(gson.toJson(bidsList), String[][].class);
+ String[] bidsData = dataArray[0];
+ HashMap<String, Object> pvMap = new HashMap<>(); // 创建新的 HashMap 保存 bids 和 asks
+ pvMap.put("p", new BigDecimal(bidsData[0]).toPlainString());
+ pvMap.put("v", new BigDecimal(bidsData[1]).toPlainString());
+ hashMap.put(ASKS_KEY,pvMap);
+ }
- String key = "gate" + resultMap.get(S_KEY); // 生成 Redis 键
- RedisUtil.set(key.replace("_", ""), gson.toJson(hashMap)); // 存入 Redis,使用 Gson 进行序列化
+ String key = "gate" + resultMap.get(S_KEY); // 生成 Redis 键
+ RedisUtil.set(key.replace("_", ""), gson.toJson(hashMap)); // 存入 Redis,使用 Gson 进行序列化
+ }
}
} catch (JsonSyntaxException e) {
log.error("JSON 解析异常:" + e.getMessage(), e); // 记录 JSON 解析异常
@@ -141,6 +141,7 @@
}
+
@OnClose
public void onClose() {
log.info("gate ws 连接已关闭,尝试重新连接..."); // 连接关闭日志
--
Gitblit v1.9.3