From edaa364ccc37fe5372bca577482dd5d7142425cd Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Mon, 05 Aug 2024 18:30:53 +0800
Subject: [PATCH] 1
---
geteClient/src/main/java/org/example/geteclient/wsClinet/GateClient.java | 30 ++++++++++++++++++++++++++----
1 files changed, 26 insertions(+), 4 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 94024f1..7ef4318 100644
--- a/geteClient/src/main/java/org/example/geteclient/wsClinet/GateClient.java
+++ b/geteClient/src/main/java/org/example/geteclient/wsClinet/GateClient.java
@@ -11,6 +11,7 @@
import org.json.JSONException;
import javax.websocket.*;
+import java.math.BigDecimal;
import java.net.URI;
import java.nio.ByteBuffer;
import java.util.Arrays;
@@ -91,6 +92,8 @@
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
@@ -104,9 +107,28 @@
if (resultMap != null && resultMap.get(S_KEY) != null) {
HashMap<String, Object> hashMap = new HashMap<>(); // 创建新的 HashMap 保存 bids 和 asks
- // 放入 bids 和 asks 数据
- hashMap.put(BIDS_KEY, resultMap.get(BIDS_KEY)); // 放入 bids 数据
- hashMap.put(ASKS_KEY, resultMap.get(ASKS_KEY)); // 放入 asks 数据
+ 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 (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);
+ }
String key = "gate" + resultMap.get(S_KEY); // 生成 Redis 键
RedisUtil.set(key.replace("_", ""), gson.toJson(hashMap)); // 存入 Redis,使用 Gson 进行序列化
@@ -189,7 +211,7 @@
final String CHANNEL = "spot.order_book"; // 固定频道名称
final String EVENT_SUBSCRIBE = "subscribe"; // 订阅事件
final String EVENT_UNSUBSCRIBE = "unsubscribe"; // 取消订阅事件
- final String[] PAYLOAD = new String[]{symbol, "20", "100ms"}; // 请求负载信息
+ final String[] PAYLOAD = new String[]{symbol, "5", "100ms"}; // 请求负载信息
// 使用Map构建JSON对象
Map<String, Object> jsonMap = new HashMap<>(); // 创建 Map 存放 JSON 内容
--
Gitblit v1.9.3