头图

在当今的数字货币市场中,实时行情数据对交易者和投资者至关重要。通过API查询虚拟货币的实时价格,用户可以获取市场的最新波动信息,从而更好地制定交易策略、分析市场趋势,并实现高效的自动化交易。API通常提供实时的价格更新、K线数据、成交量等关键市场数据,帮助交易者随时掌握市场动态。

这里我们将使用Java调取外部接口,查询虚拟币的实时行情。实时行情指的是即时获取的市场价格和成交数据,这些数据在交易发生后立即更新,通常几秒内(有些高频交易专用的接口能干到一秒以内)就能传递给用户。

相对而言,延时行情通常会有一段时间的延迟,最常见的是15分钟的延时。延时行情主要用于满足普通投资者或数据分析需求,因为它不具备实时交易的及时性,但仍然可以提供市场的大致走势。延时行情是比较常见的,我们平时看的财经网站、或者股票交易软件上的行情基本都属于延时数据。

HTTP请求

下面我们试着通过接口查询狗狗币(DOGE)的行情

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
 
public class HttpJavaExample {
 
    public static void main(String[] args) {
 
        try {
 
            /*
            接口注册地址:https://alltick.io/
            Github:https://github.com/alltick
            Replace "testtoken" with your actual token from AllTick API.
            */
            String url = "http://quote.tradeswitcher.com/quote-b-api/kline?token=testtoken&query=%7B%22trace%22%3A%22java_http_test1%22%2C%22data%22%3A%7B%22code%22%3A%22DOGEUSDT%22%2C%22kline_type%22%3A1%2C%22kline_timestamp_end%22%3A0%2C%22query_kline_num%22%3A2%2C%22adjust_type%22%3A0%7D%7D";
 
            URL obj = new URL(url);
            HttpURLConnection con = (HttpURLConnection) obj.openConnection();
 
            con.setRequestMethod("GET");
 
            int responseCode = con.getResponseCode();
            System.out.println("Response Code: " + responseCode);
 
            BufferedReader in = new BufferedReader(new InputStreamReader(con.getInputStream()));
            String inputLine;
            StringBuffer response = new StringBuffer();
 
            while ((inputLine = in.readLine()) != null) {
                response.append(inputLine);
            }
 
            in.close();
 
            System.out.println(response.toString());
 
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

这段代码的基础逻辑是通过Java发起HTTP请求,查询指定虚拟货币的行情数据。代码步骤如下:

  1. 构建URL:代码中定义了API的请求URL,包含查询参数(例如交易对DOGEUSDT)和API访问令牌(token)。
  2. 建立HTTP连接:使用HttpURLConnection类建立到API服务器的连接,并指定请求方法为GET。
  3. 获取响应:发送请求后,代码通过getResponseCode()方法检查服务器的响应状态,并通过输入流InputStream读取API的返回数据。
  4. 输出结果:将API返回的JSON格式数据逐行读取并拼接到字符串中,最后打印出来,供后续解析或使用。

WebSockets

WebSocket是一种全双工通信协议,允许客户端和服务器之间建立持久的连接,从而实现实时数据传输。相比于传统的HTTP轮询,WebSocket具有以下优势:

实时性高:一旦建立连接,服务器可以实时地向客户端推送数据,极大地降低了延迟。尤其在金融市场和在线游戏等对数据更新频率要求较高的场景中,WebSocket是理想选择。

高效性:WebSocket建立一次连接后即可持续通信,避免了HTTP协议中的频繁握手。这样不仅减少了请求的开销,还减轻了服务器的负担。

低延迟与节省带宽:WebSocket传输的是较少的头信息,节省了网络带宽,适合高频次、低延迟的数据传输,如价格行情更新、消息通知等。

下面我们通过WebSockts来订阅比特币(BTC)的行情数据:

import java.io.IOException;
import java.net.URI;
import java.net.URISyntaxException;
import javax.websocket.*;
 
/*
接口注册地址:https://alltick.io/
Github:https://github.com/alltick
*/
 
@ClientEndpoint
public class WebSocketJavaExample {
 
    private Session session;
 
    @OnOpen
    public void onOpen(Session session) {
        System.out.println("Connected to server");
        this.session = session;
    }
 
    @OnMessage
    public void onMessage(String message) {
        System.out.println("Received message: " + message);
    }
 
    @OnClose
    public void onClose(Session session, CloseReason closeReason) {
        System.out.println("Disconnected from server");
    }
 
    @OnError
    public void onError(Throwable throwable) {
        System.err.println("Error: " + throwable.getMessage());
    }
 
    public void sendMessage(String message) throws Exception {
        this.session.getBasicRemote().sendText(message);
    }
 
    public static void main(String[] args) throws Exception, URISyntaxException, DeploymentException, IOException {
        WebSocketContainer container = ContainerProvider.getWebSocketContainer();
        URI uri = new URI("wss://quote.tradeswitcher.com/quote-b-ws-api?token=testtoken"); // Replace with your actual token
 
        WebSocketJavaExample client = new WebSocketJavaExample();
        container.connectToServer(client, uri);
 
        // Send subscription message for BTCUSDT
        client.sendMessage("{\"cmd_id\": 22002, \"seq_id\": 123, \"trace\":\"unique-trace-id\",\"data\":{\"symbol_list\":[{\"code\": \"BTCUSDT\",\"depth_level\": 5}]}}");
 
        // Wait for the client to be disconnected from the server (or until the user presses Enter)
        System.in.read(); // Wait for user input before closing the program
    }
}

这段代码的基本流程如下:

  1. 定义WebSocket客户端:使用@ClientEndpoint注解将WebSocketJavaExample类标记为WebSocket客户端,并定义了一些事件处理方法(如onOpen、onMessage、onClose、onError)用于处理不同的WebSocket连接事件。
  2. 连接到服务器:在main方法中,使用WebSocketContainer建立到WebSocket服务器的连接(在这里为行情数据服务器)。连接的URL中包含了API令牌,确保服务器验证用户身份。
  3. 发送订阅请求:建立连接后,通过sendMessage方法发送订阅消息,以请求服务器提供BTCUSDT(比特币/美元)交易对的实时行情数据。消息内容使用JSON格式,并指定了需要的交易对(BTCUSDT)和深度级别等参数。
  4. 接收并处理消息:当服务器返回行情数据时,onMessage方法会被调用,打印出接收到的行情信息。通过这种方式,客户端可以持续接收BTCUSDT的实时价格更新。
  5. 关闭连接:当连接被关闭或发生错误时,onClose和onError方法会被触发,输出相应信息。

更多教程可以查看这个Github:https://github.com/alltick


TickTank
2 声望1 粉丝

高频tick数据行情接口