美股 (US) 与 墨西哥 (Mexico) 股票数据接口集成指南

1. 接入概述 (General)

本接口用于获取美国(NYSE, NASDAQ, AMEX)及墨西哥(BMV, BIVA)证券市场的实时行情、历史 K 线及指数数据。

  • API Base URL : https://api.stocktv.top
  • WebSocket URL : wss://ws-api.stocktv.top/connect
  • 鉴权方式 : 所有请求均需携带 URL 参数 key=您的API密钥

1.1 关键市场 ID (Country ID)

在调用相关接口时,请务必区分以下 countryId

市场名称 Country ID 交易所示例
美国 (USA) 5 NYSE (1), NASDAQ (2), AMEX
墨西哥 (Mexico) 7 Mexico (53), BIVA (144)

2. 核心数据接口

2.1 获取股票列表 (Stock List)

用于查询指定市场的股票清单,获取股票的名称、代码 (Symbol) 和 系统 ID (PID)

注意id (PID) 是后续查询 K 线和订阅 WebSocket 的唯一标识符。

  • 接口地址 : /stock/stocks
  • 请求方式 : GET
  • 请求参数:
参数名 类型 必填 说明
key String 您的 API Key
countryId Int 5 (美股) 或 7 (墨西哥)
pageSize Int 每页数量 (默认 10)
page Int 页码 (默认 1)
  • 请求示例 (获取美股列表):

    http 复制代码
    GET https://api.stocktv.top/stock/stocks?countryId=5&pageSize=20&page=1&key=YOUR_KEY
  • 响应示例:

    json 复制代码
    {
      "code": 200,
      "data": {
        "records": [
          {
            "id": 8888,          // [关键] PID,用于K线接口
            "name": "Apple Inc", // 股票名称
            "symbol": "AAPL",    // 股票代码
            "exchangeId": 2,     // 交易所ID (2=NASDAQ)
            "last": 180.5,       // 最新价
            "chgPct": 1.25,      // 涨跌幅%
            "countryNameTranslated": "United States"
          }
        ]
      }
    }

2.2 获取 K 线数据 (Candlestick Data)

获取指定股票的历史行情数据,支持多种时间周期。

  • 接口地址 : /stock/kline
  • 请求方式 : GET
  • 请求参数:
参数名 类型 必填 说明
key String 您的 API Key
pid Int 股票系统 ID (通过 2.1 接口获取)
interval String K线周期 (ISO 8601格式)
  • 周期 (Interval) 说明:

    • PT1M (1分钟), PT5M (5分钟), PT15M (15分钟), PT30M (30分钟), PT1H (1小时)
    • P1D (日线), P1W (周线), P1M (月线)
  • 请求示例 (获取墨西哥某股票日线):

    http 复制代码
    GET https://api.stocktv.top/stock/kline?pid=12345&interval=P1D&key=YOUR_KEY
  • 响应示例:

    json 复制代码
    {
      "code": 200,
      "data": [
        {
          "time": 1719818400000, // 时间戳 (毫秒)
          "open": 150.0,
          "high": 155.0,
          "low": 149.0,
          "close": 153.0,
          "volume": 200000
        }
      ]
    }

2.3 获取大盘指数 (Indices)

获取美股(如纳斯达克、标普500)或墨西哥(如 S&P/BMV IPC)的指数行情。

  • 接口地址 : /stock/indices

  • 请求方式 : GET

  • 请求参数 : countryId (5=美国, 7=墨西哥)

  • 请求示例:

    http 复制代码
    GET https://api.stocktv.top/stock/indices?countryId=7&key=YOUR_KEY

3. WebSocket 实时推送

通过 WebSocket 长连接接收实时报价更新。

  • 连接地址 : wss://ws-api.stocktv.top/connect?key=YOUR_KEY

  • 心跳机制: 连接建立后,建议定期发送心跳包以保持连接。

  • 推送数据结构 :

    json 复制代码
    {
        "pid": "8888",         // 对应 Rest API 中的 id
        "last_numeric": 181.2, // 最新价
        "pcp": "0.39",         // 涨跌幅%
        "timestamp": "1717728251",
        "bid": "181.1",        // 买价
        "ask": "181.3",        // 卖价
        "type": 1              // 1=股票, 2=指数
    }

4. 接入代码示例 (JavaScript)

以下代码展示了如何根据 countryId 封装获取美股和墨西哥股票的逻辑。

javascript 复制代码
const API_KEY = 'YOUR_API_KEY';
const BASE_URL = 'https://api.stocktv.top';

// 配置 ID
const MARKETS = {
    USA: 5,
    MEXICO: 7
};

/**
 * 获取指定市场的股票列表
 * @param {number} countryId - 5 for USA, 7 for Mexico
 */
async function getMarketStocks(countryId) {
    const url = `${BASE_URL}/stock/stocks?countryId=${countryId}&pageSize=10&page=1&key=${API_KEY}`;
    try {
        const response = await fetch(url);
        const result = await response.json();
        
        if (result.code === 200) {
            console.log(`市场 (ID:${countryId}) 股票列表:`, result.data.records);
            // 示例:获取第一个股票的 PID 用于查 K 线
            if(result.data.records.length > 0) {
                const firstStock = result.data.records[0];
                console.log(`示例股票: ${firstStock.name}, PID: ${firstStock.id}`);
            }
        }
    } catch (error) {
        console.error('API 请求失败:', error);
    }
}

// 1. 获取美股数据
getMarketStocks(MARKETS.USA);

// 2. 获取墨西哥股票数据
getMarketStocks(MARKETS.MEXICO);
相关推荐
张人大 Renda Zhang42 分钟前
Java 虚拟线程 Virtual Thread:让“每请求一线程”在高并发时代复活
java·jvm·后端·spring·架构·web·虚拟线程
一勺菠萝丶1 小时前
解决 SLF4J 警告问题 - 完整指南
java·spring boot·后端
零日失眠者1 小时前
【文件管理系列】001:文件批量重命名工具
后端·shell
申阳1 小时前
Day 19:02. 基于 SpringBoot4 开发后台管理系统-项目初始化
前端·后端·程序员
Undoom1 小时前
openEuler iSula 容器引擎关键性能指标量化评测
后端
q_19132846952 小时前
基于Springboot2+Vue2的旅游景点购票系统
java·vue.js·spring boot·后端·mysql·毕业设计·计算机毕业设计
哈哈哈笑什么2 小时前
基于RabbitMQ的企业级订单系统设计与实现
后端
LSTM972 小时前
使用 Java 实现条形码生成与识别
后端
哈哈哈笑什么2 小时前
如何防止恶意伪造前端唯一请求id
前端·后端