From 83f9014a75f572154ae7732f0fc78d6467edde93 Mon Sep 17 00:00:00 2001
From: peter <908253177@qq.com>
Date: Tue, 08 Jul 2025 14:56:52 +0800
Subject: [PATCH] 外汇

---
 trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/XinLangDataServiceImpl.java |  177 ++++++++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 134 insertions(+), 43 deletions(-)

diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/XinLangDataServiceImpl.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/XinLangDataServiceImpl.java
index a6e9c70..12918b0 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/XinLangDataServiceImpl.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/XinLangDataServiceImpl.java
@@ -4,16 +4,22 @@
 import com.alibaba.fastjson.JSON;
 import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
+import com.fasterxml.jackson.databind.ObjectMapper;
 import com.google.common.base.Splitter;
 import com.google.common.collect.Lists;
 import com.yami.trading.bean.cms.Infomation;
 import com.yami.trading.bean.data.domain.*;
+import com.yami.trading.bean.data.respDto.TradeTickResp;
 import com.yami.trading.common.util.RedisUtil;
 import com.yami.trading.common.util.StringUtils;
+import com.yami.trading.common.util.UTCDateUtils;
 import com.yami.trading.huobi.data.DataCache;
 import com.yami.trading.huobi.data.internal.DepthTimeObject;
 import com.yami.trading.huobi.data.internal.KlineService;
 import com.yami.trading.huobi.data.internal.TradeTimeObject;
+import com.yami.trading.huobi.data.model.AlltickBatchKlineResult;
+import com.yami.trading.huobi.data.model.AlltickNewPriceResult;
+import com.yami.trading.huobi.data.model.AllticktradeResult;
 import com.yami.trading.huobi.hobi.http.HttpHelper;
 import com.yami.trading.huobi.hobi.http.HttpMethodType;
 import com.yami.trading.service.cms.InfomationService;
@@ -24,15 +30,14 @@
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
 import org.springframework.stereotype.Component;
 
 import java.math.BigDecimal;
 import java.math.RoundingMode;
+import java.net.URLEncoder;
 import java.text.SimpleDateFormat;
-import java.time.LocalDate;
-import java.time.Month;
-import java.time.ZoneId;
-import java.time.ZonedDateTime;
+import java.time.*;
 import java.time.format.DateTimeFormatter;
 import java.util.*;
 import java.util.regex.Matcher;
@@ -55,6 +60,7 @@
      */
 //    public final static String live = "https://hq.sinajs.cn/rn={1}list={2}";//todo 要调整
     public final static String live = "https://hq.sinajs.cn/etag.php?_={1}&list={2}";//todo 要调整
+    public final static String live_tick = "https://quote.alltick.io/quote-b-api/kline?token={1}&query={2}";
 
 
     private static Logger logger = LoggerFactory.getLogger(XinLangDataServiceImpl.class);
@@ -64,10 +70,15 @@
     @Autowired
     private ItemService itemService;
 
+    @Value("${alltick.trade-tick}")
+    private String tradeTick;
+    @Value("${alltick.batch-kline}")
+    private String batchKline;
+
 
     public static void main(String[] args) {
         XinLangDataServiceImpl service = new XinLangDataServiceImpl();
-        List<Realtime> usdsgd = service.realtimeSingle("USDSGD");
+        List<Realtime> usdsgd = service.realtimeSingle("USDJPY");
         for (Realtime re : usdsgd) {
             System.out.println(JSONObject.toJSONString(re));
         }
@@ -76,8 +87,57 @@
 //        List<Kline> eurusd = service.getTimeseriesByPeriodOneDay("EURUSD");
 //        System.out.println(JSONObject.toJSONString(eurusd));
     }
+    public Map<String, Object> createRequest(List<String> strings) {
+        Map<String, Object> requestData = new HashMap<>();
+        Map<String, Object> data = new HashMap<>();
+        List<Map<String, Object>> dataList = new ArrayList<>();
+        for (String symbolCode : strings) {
+            for (int i = 1; i <= 3; i++) {
+                Map<String, Object> dataItem = new HashMap<>();
+                dataItem.put("code", symbolCode);
+                dataItem.put("kline_type", i);
+                dataItem.put("kline_timestamp_end", 0);
+                dataItem.put("query_kline_num", 1);
+                dataList.add(dataItem);
+            }
+        }
+        data.put("data_list", dataList);
+        requestData.put("trace", UUID.randomUUID().toString());
+        requestData.put("data", data);
+        return requestData;
+    }
 
+    public Map<String, Object> createRequestTick(List<String> strings) {
+        // 创建 JSON 对象
+        JSONObject response = new JSONObject();
+        response.put("trace", UUID.randomUUID().toString());
+        // 创建数据部分
+        JSONObject dataObject = new JSONObject();
+        JSONArray symbolList = new JSONArray();
 
+        // 构造符号列表
+        for (String code : strings) {
+            JSONObject symbol = new JSONObject();
+            symbol.put("code", code);
+            symbolList.add(symbol);
+        }
+
+        dataObject.put("symbol_list", symbolList);
+        response.put("data", dataObject);
+        return response;
+    }
+
+    public Map<String, Object> createRequestZdf(String symbolCode) {
+        JSONObject json = new JSONObject();
+        json.put("trace", UUID.randomUUID().toString());
+        JSONObject data = new JSONObject();
+        data.put("code", symbolCode);
+        data.put("kline_type", 8);
+        data.put("kline_timestamp_end", 0);
+        data.put("query_kline_num", 2);
+        json.put("data", data);
+        return json;
+    }
     /**
      * 获取原始的K线图数据
      *
@@ -92,49 +152,80 @@
         return HttpHelper.sendGetHttp(url, null, cookie);
     }
 
+    public List<Realtime> realtimeNewPrice(String symbols,List<Realtime> realtimes) {
+        //获取最新价
+        try{
+            List<String> strings = Arrays.asList(symbols.split(","));
+            Map<String, Object> requestDataTick = createRequestTick(strings);
+            String url = tradeTick.replace("{1}", URLEncoder.encode(requestDataTick.toString(), "UTF-8"));
+            HttpGet request = new HttpGet(url);
+            HttpResponse response = HttpHelper.getHttpclient().execute(request);
+            String resultTickStr = HttpHelper.responseProc(response);
+            JSONObject resultJsonTick = JSON.parseObject(resultTickStr);
+            if(null == resultJsonTick || 200 != resultJsonTick.getInteger("ret")){
+                logger.error("数据,返回:{} ", resultJsonTick);
+            }
+
+            JSONObject tempdataTick = resultJsonTick.getJSONObject("data");
+            JSONArray dataArrayTick = tempdataTick.getJSONArray("tick_list");
+            if (dataArrayTick.size() > 0) {
+                List<AlltickNewPriceResult> alltickNewPriceResults = JSONObject.parseArray(JSONObject.toJSONString(dataArrayTick), AlltickNewPriceResult.class);
+                for (AlltickNewPriceResult tickNewPrice : alltickNewPriceResults) {
+                    for (Realtime realtime : realtimes){
+                        if(tickNewPrice.getCode().equals(realtime.getName())){
+                            realtime.setCloseOld(realtime.getClose());
+                            realtime.setClose(new BigDecimal(tickNewPrice.getPrice()));
+                            realtime.setVolume(new BigDecimal(tickNewPrice.getVolume()));
+                        }
+                    }
+                }
+            }
+        } catch (Exception e){
+            logger.error("error", e);
+        }
+        for (Realtime realtime : realtimes) {
+            if(realtime.getName().equals("USDSGD")){
+                System.out.println("USDSGD实时价格数据替换前=="+realtime.getCloseOld());
+                System.out.println("USDSGD实时价格数据替换后=="+realtime.getClose());
+            }
+        }
+        return realtimes;
+    }
     public List<Realtime> realtimeSingle(String symbols) {
         List<Realtime> list = new ArrayList<Realtime>();
         try {
             List<String> strings = Arrays.asList(symbols.split(","));
-            for (String symbol: strings) {
-                String url = live.replace("{1}",System.currentTimeMillis()+"").replace("{2}", "fx_s"+symbol.toLowerCase());
-                HttpGet request = new HttpGet(url);
-                request.addHeader("Referer","https://finance.sina.com.cn");
-                request.setHeader("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/100.0.4896.60 Safari/537.36");
-                HttpResponse response = HttpHelper.getHttpclient().execute(request);
-                String result = HttpHelper.responseProc(response);
-                int firstQuoteIndex = result.indexOf("\"");
-                int secondQuoteIndex = result.indexOf("\"", firstQuoteIndex + 1);
-                String extractedString = result.substring(firstQuoteIndex + 1, secondQuoteIndex);
-                if(extractedString.split(",").length != 18){
-                    return list;
+            Map<String, Object> requestData = createRequest(strings);
+            String resultStr = HttpHelper.sendPostRequest(batchKline,requestData);
+            JSONObject resultJson = JSON.parseObject(resultStr);
+            if(null == resultJson || 200 != resultJson.getInteger("ret")){
+                logger.error("数据,返回:{} ", resultJson);
+            }
+            JSONObject tempdata = resultJson.getJSONObject("data");
+            JSONArray dataArray = tempdata.getJSONArray("kline_list");
+            if (dataArray.size() > 0) {
+                List<AlltickBatchKlineResult> batchKlines = JSONObject.parseArray(JSONObject.toJSONString(dataArray), AlltickBatchKlineResult.class);
+                for (AlltickBatchKlineResult batchKline : batchKlines) {
+                    for (AllticktradeResult result : batchKline.getKline_data()){
+                        Realtime realtime = new Realtime();
+                        int decimal = itemService.getDecimal(batchKline.getCode());
+                        realtime.setSymbol(batchKline.getCode());
+                        realtime.setTs(Long.parseLong(result.getTimestamp()));
+                        realtime.setName(batchKline.getCode());
+                        realtime.setOpen(result.getOpen_price().setScale(decimal, RoundingMode.HALF_UP));
+                        realtime.setHigh(result.getHigh_price().setScale(decimal, RoundingMode.HALF_UP));
+                        realtime.setLow(result.getLow_price().setScale(decimal, RoundingMode.HALF_UP));
+                        realtime.setClose(result.getClose_price().setScale(decimal, RoundingMode.HALF_UP));
+                        realtime.setMarketCapital(0L);
+                        realtime.setFloatMarketCapital(0L);
+                        realtime.setPeForecast(BigDecimal.ZERO);
+                        realtime.setVolumeRatio(BigDecimal.ZERO);
+                        realtime.setTurnoverRate(BigDecimal.ZERO);
+                        realtime.setAmount(result.getVolume());
+                        realtime.setVolume(result.getTurnover());
+                        list.add(realtime);
+                    }
                 }
-                String[] split = extractedString.split(",");
-                SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
-                Date date = sdf.parse(split[17]+" " +split[0]);
-                long timestamp = date.getTime();
-                Realtime realtime = new Realtime();
-                int decimal = itemService.getDecimal(symbol);
-                realtime.setSymbol(symbol);
-                realtime.setTs(timestamp);
-                realtime.setName(symbol);
-                realtime.setOpen(BigDecimal.valueOf(Double.parseDouble(split[5])).setScale(decimal, RoundingMode.HALF_UP));
-                realtime.setHigh(BigDecimal.valueOf(Double.parseDouble(split[6])).setScale(decimal, RoundingMode.HALF_UP));
-                realtime.setLow(BigDecimal.valueOf(Double.parseDouble(split[7])).setScale(decimal, RoundingMode.HALF_UP));
-                if(StringUtils.isNotEmpty(split[1])){
-                    realtime.setClose(BigDecimal.valueOf(Double.parseDouble(split[1])).setScale(decimal, RoundingMode.HALF_UP));
-                }else{
-                    realtime.setClose(BigDecimal.valueOf(Double.parseDouble(split[7])).setScale(decimal, RoundingMode.HALF_UP));
-                }
-                realtime.setMarketCapital(0L);
-                realtime.setFloatMarketCapital(0L);
-                realtime.setPeForecast(BigDecimal.ZERO);
-                realtime.setVolumeRatio(BigDecimal.ZERO);
-                realtime.setTurnoverRate(BigDecimal.ZERO);
-
-                realtime.setAmount(BigDecimal.ZERO);
-                realtime.setVolume(BigDecimal.ZERO);
-                list.add(realtime);
             }
         } catch (Exception e) {
             logger.error("error", e);

--
Gitblit v1.9.3