| | |
| | | import com.nq.pojo.StockRealTimeBean; |
| | | import com.nq.service.IMandatoryLiquidationService; |
| | | import com.nq.service.impl.MandatoryLiquidationService; |
| | | import com.nq.utils.ApplicationContextRegisterUtil; |
| | | import com.nq.utils.redis.RedisKeyUtil; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.apache.http.HttpResponse; |
| | |
| | | import java.util.*; |
| | | |
| | | @Slf4j |
| | | public class WebsocketRunClient extends WebSocketClient { |
| | | public class WebsocketRunClient extends WebSocketClient { |
| | | |
| | | private EStockType eStockType; |
| | | |
| | | public WebsocketRunClient(URI serverUri, EStockType eStockType) { |
| | | // 修改为新的WebSocket服务器地址 |
| | | super(URI.create("wss://usws.yanshiz.com/websocket-server")); |
| | | public WebsocketRunClient(URI serverUri, |
| | | EStockType eStockType |
| | | ) { |
| | | super(serverUri); |
| | | this.eStockType = eStockType; |
| | | } |
| | | |
| | | private static HttpClient httpClient = HttpClients.createDefault(); // 单例化 HttpClient |
| | | |
| | | |
| | | private static HttpPost httpPost; |
| | | static { |
| | | httpPost = new HttpPost("http://127.0.0.1:8008/api/sendNotification"); // 初始化 HttpPost |
| | | } |
| | | |
| | | @Override |
| | | public void onOpen(ServerHandshake serverHandshake) { |
| | | log.info("WebSocket连接已建立,连接到: wss://usws.yanshiz.com/websocket-server"); |
| | | // 发送身份验证消息 |
| | | send(("key:"+ eStockType.getStockKey()+":"+eStockType.getContryId()).getBytes()); |
| | | Timer heartbeatTimer; |
| | | // 启动心跳定时器 |
| | |
| | | heartbeatTimer.schedule(new TimerTask() { |
| | | @Override |
| | | public void run() { |
| | | if (isOpen()) { |
| | | send(("key:"+ eStockType.getStockKey()+":"+eStockType.getContryId()).getBytes()); |
| | | } |
| | | send(("key:"+ eStockType.getStockKey()+":"+eStockType.getContryId()).getBytes()); |
| | | } |
| | | }, 0, 3000); // 每3秒发送一次心跳消息 |
| | | } |
| | |
| | | @Override |
| | | public void onMessage(String s) { |
| | | if(!s.equals("pong") && !s.equals("身份验证成功")){ |
| | | Map<String, String> stringObjectMap = jsonToMap(s); |
| | | StockRealTimeBean stockRealTimeBean = new StockRealTimeBean(); |
| | | stockRealTimeBean.setPid(stringObjectMap.get("Id").toString()); |
| | | stockRealTimeBean.setLast(stringObjectMap.get("Last").toString()); |
| | | stockRealTimeBean.setBid(stringObjectMap.get("Bid").toString()); |
| | | stockRealTimeBean.setAsk(stringObjectMap.get("Ask").toString()); |
| | | stockRealTimeBean.setHigh(stringObjectMap.get("High").toString()); |
| | | stockRealTimeBean.setLow(stringObjectMap.get("Low").toString()); |
| | | stockRealTimeBean.setPc(stringObjectMap.get("Chg").toString()); |
| | | stockRealTimeBean.setPcp(stringObjectMap.get("ChgPct").toString()+"%"); |
| | | stockRealTimeBean.setTime(stringObjectMap.get("Time").toString()); |
| | | stockRealTimeBean.setOpen(stringObjectMap.get("Open")); |
| | | stockRealTimeBean.setPrevClose(stringObjectMap.get("PrevClose")); |
| | | stockRealTimeBean.setSymbol(stringObjectMap.get("Symbol")); |
| | | |
| | | RedisKeyUtil.setCacheRealTimeStock(EStockType.US,stockRealTimeBean); |
| | | ObjectMapper objectMapper = new ObjectMapper(); |
| | | try { |
| | | Map<String, String> stringObjectMap = jsonToMap(s); |
| | | StockRealTimeBean stockRealTimeBean = new StockRealTimeBean(); |
| | | stockRealTimeBean.setPid(stringObjectMap.get("Id")); |
| | | stockRealTimeBean.setLast(stringObjectMap.get("Last")); |
| | | stockRealTimeBean.setBid(stringObjectMap.get("Bid")); |
| | | stockRealTimeBean.setAsk(stringObjectMap.get("Ask")); |
| | | stockRealTimeBean.setHigh(stringObjectMap.get("High")); |
| | | stockRealTimeBean.setLow(stringObjectMap.get("Low")); |
| | | stockRealTimeBean.setPc(stringObjectMap.get("Chg")); |
| | | stockRealTimeBean.setPcp(stringObjectMap.get("ChgPct") + "%"); |
| | | stockRealTimeBean.setTime(stringObjectMap.get("Time")); |
| | | stockRealTimeBean.setOpen(stringObjectMap.get("Open")); |
| | | stockRealTimeBean.setPrevClose(stringObjectMap.get("PrevClose")); |
| | | |
| | | RedisKeyUtil.setCacheRealTimeStock(EStockType.US, stockRealTimeBean); |
| | | |
| | | ObjectMapper objectMapper = new ObjectMapper(); |
| | | if(!stockRealTimeBean.getPcp().contains("-")){ |
| | | stockRealTimeBean.setPcp("+" + stringObjectMap.get("ChgPct") + "%"); |
| | | stockRealTimeBean.setPcp("+"+stringObjectMap.get("ChgPct").toString()+"%"); |
| | | } |
| | | |
| | | StockRealTimeBean stockDetailBean = new Gson().fromJson(s, StockRealTimeBean.class); |
| | | RedisKeyUtil.setCacheRealTimeStock(EStockType.US, stockDetailBean); |
| | | |
| | | } catch (Exception e) { |
| | | log.error("处理WebSocket消息时发生错误: {}", e.getMessage(), e); |
| | | String json = objectMapper.writeValueAsString(stockRealTimeBean); |
| | | sendLoca(json); |
| | | StockRealTimeBean stockDetailBean = new Gson().fromJson(s, StockRealTimeBean.class); |
| | | RedisKeyUtil.setCacheRealTimeStock(EStockType.US,stockDetailBean); |
| | | } catch (JsonProcessingException e) { |
| | | throw new RuntimeException(e); |
| | | } |
| | | |
| | | } else { |
| | | log.info("WebSocket心跳或认证响应: {}", s); |
| | | }else{ |
| | | log.error("websocket 消息错误:"+s); |
| | | } |
| | | } |
| | | |
| | |
| | | |
| | | @Override |
| | | public void onClose(int i, String s, boolean b) { |
| | | log.info("WebSocket连接已关闭,代码: {}, 原因: {}, 远程关闭: {}", i, s, b); |
| | | log.info("websocket 印度股票 关闭"+1); |
| | | } |
| | | |
| | | @Override |
| | | public void onError(Exception e) { |
| | | log.error("WebSocket连接发生错误: {}", e.getMessage(), e); |
| | | log.info("websocket 错误"); |
| | | } |
| | | |
| | | public void sendLoca(String message) { |
| | | try { |
| | | // 准备 form-data 参数 |
| | | List<BasicNameValuePair> params = new ArrayList<>(); |
| | | params.add(new BasicNameValuePair("message", message)); |
| | | |
| | | // 设置编码格式为 UTF-8 |
| | | UrlEncodedFormEntity entity = new UrlEncodedFormEntity(params, StandardCharsets.UTF_8); |
| | | httpPost.setEntity(entity); // 设置 HttpPost 对象的参数 |
| | | |
| | | // 发送请求 |
| | | HttpResponse response = httpClient.execute(httpPost); |
| | | |
| | | // 处理响应 |
| | | int statusCode = response.getStatusLine().getStatusCode(); |
| | | } catch (IOException e) { |
| | | log.error("Http 请求错误", e); |
| | | } |
| | | } |
| | | } |