Tiger OpenAPI C++ SDK 是老虎证券开放平台的官方 C++ 客户端,提供交易、行情、长连接推送等功能。
English | 中文
- 🚀 完整的交易接口支持(下单、撤单、查询持仓等)
- 📊 实时行情数据获取(K线、报价、逐笔成交等)
- 🔌 WebSocket 长连接推送(持仓、订单、行情实时推送)
- 🌐 跨平台支持(macOS、Linux、Windows)
- 🛡️ 类型安全的 C++ API 设计
- 📦 支持静态库和动态库编译
| 平台 | 编译器 | CMake | 依赖管理 |
|---|---|---|---|
| macOS | Clang (Xcode) | 3.15+ | Homebrew + 源码 |
| Linux | GCC/G++ | 3.15+ | apt + 源码 |
| Windows | MSVC 2019/2022 | 3.15+ | vcpkg |
- Boost 1.86.0(system, thread, log, program_options, chrono, filesystem)
- OpenSSL 1.0.1+(推荐 3.x)
- cpprestsdk 最新版(HTTP 客户端)
- Protobuf 5.28.3
- Abseil 20240722+(Protobuf 运行时依赖)
- C++ 标准: C++17
# 赋予执行权限(仅首次)
chmod +x scripts/build_linux_mac.sh
# 默认构建(Debug 模式,自动安装依赖并运行 demo)
./scripts/build_linux_mac.sh
# Release 模式构建
BUILD_TYPE=Release ./scripts/build_linux_mac.sh
# 仅构建 SDK,跳过 demo
SKIP_DEMO=1 ./scripts/build_linux_mac.sh脚本会自动完成:
- 安装系统依赖(Homebrew/apt)
- 编译 Boost、cpprestsdk、Protobuf
- 构建 SDK(Debug + Release)
- 构建并运行 demo
# 在 Developer PowerShell 中构建 SDK(x64 Release MD)
msbuild openapi-cpp-sdk.vcxproj /t:Rebuild /p:Configuration=Release-MD /p:Platform=x64 /m /nr:false
# 构建 demo
msbuild demo\openapi_cpp_test\openapi_cpp_test.vcxproj /t:Rebuild /p:Configuration=Release-MD /p:Platform=x64 /m /nr:false
# 重新生成 Windows 8 个预编译 zip 包
powershell -ExecutionPolicy Bypass -File scripts\package_windows.ps1如果不想从源码编译,可以直接使用 output/ 目录下的预编译库:
output/
├── Mac/
│ ├── Debug.zip # macOS Debug 静态库 + 头文件
│ └── Release.zip # macOS Release 静态库 + 头文件
├── Linux/
│ ├── Debug.zip
│ └── Release.zip
└── Windows/
├── readme.md
├── x64/
│ ├── Debug-MD.zip
│ ├── Debug-MT.zip
│ ├── Release-MD.zip
│ └── Release-MT.zip
└── Win32/
├── Debug-MD.zip
├── Debug-MT.zip
├── Release-MD.zip
└── Release-MT.zip
brew install cmake wget automake libtool pkg-config openssl@3 abseilcd /usr/local
wget https://archives.boost.io/release/1.86.0/source/boost_1_86_0.tar.bz2
tar --bzip2 -xf boost_1_86_0.tar.bz2
cd boost_1_86_0
./bootstrap.sh
./b2 headers
./b2 -j $(sysctl -n hw.ncpu)cd /tmp
git clone https://github.com/microsoft/cpprestsdk.git
cd cpprestsdk
git submodule update --init
cmake -S . -B build \
-DCMAKE_BUILD_TYPE=Debug \
-DCMAKE_INSTALL_PREFIX=/usr/local/opt/cpprestsdk \
-DBUILD_SHARED_LIBS=ON \
-DBUILD_SAMPLES=OFF \
-DBUILD_TESTS=OFF \
-DBOOST_ROOT=/usr/local/boost_1_86_0 \
-DOPENSSL_ROOT_DIR=$(brew --prefix openssl@3) \
-DCMAKE_CXX_FLAGS="-Wno-error=null-pointer-subtraction -w"
cmake --build build -- -j $(sysctl -n hw.ncpu)
sudo cmake --install buildcd /tmp
curl -sL https://github.com/protocolbuffers/protobuf/releases/download/v28.3/protobuf-28.3.tar.gz -o protobuf-28.3.tar.gz
tar xzf protobuf-28.3.tar.gz
cd protobuf-28.3
cmake -S . -B build \
-DCMAKE_BUILD_TYPE=Release \
-DCMAKE_INSTALL_PREFIX=/usr/local/opt/protobuf-v28.3 \
-DCMAKE_CXX_STANDARD=17 \
-Dprotobuf_BUILD_TESTS=OFF \
-Dprotobuf_ABSL_PROVIDER=package \
-DCMAKE_PREFIX_PATH=$(brew --prefix)
cmake --build build -- -j $(sysctl -n hw.ncpu)
sudo cmake --install buildcd <project_root>
export CPATH="$(brew --prefix abseil)/include:$CPATH"
cmake -S . -B build/Debug \
-DCMAKE_BUILD_TYPE=Debug \
-DCMAKE_INSTALL_PREFIX=/usr/local/opt/tigerapi/Debug \
-DBOOST_ROOT=/usr/local/boost_1_86_0 \
-DCMAKE_PREFIX_PATH="/usr/local/opt/cpprestsdk;/usr/local/opt/protobuf-v28.3" \
-DOPENSSL_ROOT_DIR=$(brew --prefix openssl@3)
cmake --build build/Debug -- -j $(sysctl -n hw.ncpu)
sudo cmake --install build/Debugcd demo
cmake -S . -B build \
-DCMAKE_BUILD_TYPE=Debug \
-DBOOST_ROOT=/usr/local/boost_1_86_0 \
-DTIGERAPI_INCLUDE_DIR=/usr/local/opt/tigerapi/Debug/include \
-DTIGERAPI_LIBRARY=/usr/local/opt/tigerapi/Debug/lib/libtigerapi.a \
-DCPPREST_INCLUDE_DIR=/usr/local/opt/cpprestsdk/include \
-DCPPREST_LIBRARY=/usr/local/opt/cpprestsdk/lib/libcpprest.dylib \
-DProtobuf_INCLUDE_DIR=/usr/local/opt/protobuf-v28.3/include \
-DProtobuf_LIBRARY=/usr/local/opt/protobuf-v28.3/lib/libprotobuf.dylib \
-DOPENSSL_ROOT_DIR=$(brew --prefix openssl@3)
cmake --build build -- -j $(sysctl -n hw.ncpu)
# 运行 demo(需要设置动态库路径)
export DYLD_LIBRARY_PATH="/usr/local/opt/cpprestsdk/lib:/usr/local/opt/protobuf-v28.3/lib:$DYLD_LIBRARY_PATH"
./build/openapi_cpp_testsudo apt-get update
sudo apt-get install -y git wget bzip2 unzip gcc g++ libtool automake autoconf \
build-essential cmake libssl-dev libabsl-dev zlib1g-dev pkg-config与 macOS 类似,主要区别:
- 去掉
OPENSSL_ROOT_DIR参数(Linux 上 OpenSSL 在系统路径) - 使用
LD_LIBRARY_PATH代替DYLD_LIBRARY_PATH
export LD_LIBRARY_PATH="/usr/local/opt/cpprestsdk/lib:/usr/local/opt/protobuf-v28.3/lib:$LD_LIBRARY_PATH"Windows 平台提供两种编译方式:
-
前置要求
- Visual Studio 2019 或 2022
- 安装"使用 C++ 的桌面开发"工作负载
-
准备依赖
项目使用 vcpkg 管理依赖,支持两种方式:
自动安装(推荐):
# vcpkg 会根据 vcpkg.json 自动安装依赖 # 首次打开解决方案时自动触发
手动安装:
git clone https://github.com/microsoft/vcpkg .vcpkg .\.vcpkg\bootstrap-vcpkg.bat -disableMetrics .\.vcpkg\vcpkg install --triplet x64-windows
-
打开并编译
- 双击打开
openapi-cpp-sdk.sln - 选择配置(推荐
Release-MD|x64) - 右键解决方案 → 生成解决方案
- 双击打开
-
配置说明
解决方案提供 8 种配置组合:
配置 平台 运行时库 说明 Debug-MD x64/Win32 /MDd Debug + 动态运行时 Debug-MT x64/Win32 /MTd Debug + 静态运行时 Release-MD x64/Win32 /MD Release + 动态运行时(推荐) Release-MT x64/Win32 /MT Release + 静态运行时 -
编译产物
output/Windows/ ├── x64/ │ ├── Release-MD/ │ │ ├── openapi-cpp-sdk.dll │ │ ├── openapi-cpp-sdk.lib │ │ └── openapi_cpp_test.exe │ └── Release-MT/ └── Win32/ └── ... -
依赖路径配置
工程文件已配置好依赖路径:
- Boost:
.deps/boost/boost_1_86_0(可通过环境变量BOOST_ROOT覆盖) - vcpkg 依赖:
vcpkg_installed/x64-windows/(自动管理) - SDK 头文件:
include/
- Boost:
推荐使用仓库脚本统一准备依赖并调用 CMake。Windows 下默认使用 vcpkg 安装树中的 Protobuf 5.28.3、Abseil、OpenSSL 和 cpprestsdk,避免与生成代码版本不一致;同时保留 Protobuf 源码安装路径,便于和 macOS/Linux 的 CMake 构建方式保持一致。
Set-ExecutionPolicy -Scope Process -ExecutionPolicy Bypass -Force
# 构建 SDK + demo(x64 Release MD)
.\scripts\build_windows.ps1 -Triplet x64-windows -BuildType Release -Runtime MD
# 仅构建 SDK
.\scripts\build_windows.ps1 -Triplet x64-windows -BuildType Release -Runtime MD -SkipDemo
# 使用 Protobuf 源码安装路径(默认是 vcpkg)
.\scripts\build_windows.ps1 -Triplet x64-windows -BuildType Release -Runtime MD -ProtobufProvider Source
# 重新生成 output/Windows/{Win32,x64} 下 8 个 zip 包
.\scripts\package_windows.bat
# 仅重新压缩已有输出目录,不重新编译
.\scripts\package_windows.bat -SkipBuild如果需要手动执行 CMake,可参考以下命令。
- 安装 vcpkg
git clone https://github.com/microsoft/vcpkg .vcpkg
.\.vcpkg\bootstrap-vcpkg.bat -disableMetrics- 安装依赖
.\.vcpkg\vcpkg install --triplet x64-windows- 构建 SDK
$env:VCPKG_ROOT = "$PWD\.vcpkg"
$toolchain = "$env:VCPKG_ROOT\scripts\buildsystems\vcpkg.cmake"
cmake -S . -B build\windows -A x64 `
-DCMAKE_BUILD_TYPE=Release `
-DCMAKE_TOOLCHAIN_FILE=$toolchain `
-DVCPKG_TARGET_TRIPLET=x64-windows `
-DCMAKE_PREFIX_PATH="$PWD\.deps\install\x64-windows\boost-1.86.0;$PWD\vcpkg_installed\x64-windows" `
-DBOOST_ROOT="$PWD\.deps\install\x64-windows\boost-1.86.0" `
-DProtobuf_DIR="$PWD\vcpkg_installed\x64-windows\share\protobuf" `
-DCMAKE_INSTALL_PREFIX=output\Windows\x64\Release-MD
cmake --build build\windows --config Release
cmake --install build\windows --config Release- 构建 Demo
cmake -S demo -B demo\build\windows -A x64 `
-DCMAKE_BUILD_TYPE=Release `
-DCMAKE_TOOLCHAIN_FILE=$toolchain `
-DVCPKG_TARGET_TRIPLET=x64-windows `
-DCMAKE_PREFIX_PATH="$PWD\.deps\install\x64-windows\boost-1.86.0;$PWD\vcpkg_installed\x64-windows;output\Windows\x64\Release-MD" `
-DTIGERAPI_INCLUDE_DIR=output\Windows\x64\Release-MD\include `
-DTIGERAPI_LIBRARY=output\Windows\x64\Release-MD\lib\tigerapi.lib `
-DProtobuf_DIR="$PWD\vcpkg_installed\x64-windows\share\protobuf"
cmake --build demo\build\windows --config Release --target openapi_cpp_test#include "tigerapi/quote_client.h"
TigerClient client;
client.init("your_tiger_id", "your_private_key", "your_account");
// 获取 K 线数据
std::vector<std::string> symbols = {"AAPL", "TSLA"};
ResponseModel response = client.grab_quote_kline(symbols, "day", "2024-01-01", "2024-12-31");#include "tigerapi/push_client.h"
// 创建推送客户端
PushClient push_client(tiger_id, private_key, "your_language");
// 订阅持仓推送
push_client.subscribe_position();
// 订阅行情推送
push_client.subscribe_quote({"AAPL", "TSLA"});
// 连接并接收推送
push_client.connect();更多示例请参考 demo/openapi_cpp_test/openapi_cpp_test.cpp。
openapi-cpp-sdk/
├── include/ # 头文件
│ ├── tigerapi/ # SDK 公共头文件
│ ├── cpprest/ # cpprestsdk 头文件
│ ├── google/protobuf/ # Protobuf 5.28.3 头文件
│ └── openapi_pb/ # Protobuf 生成的消息定义
├── src/ # SDK 源码实现
├── demo/ # 示例代码
│ └── openapi_cpp_test/
├── scripts/ # 构建脚本
│ ├── build_linux_mac.sh # macOS/Linux 一键构建
│ └── build_windows.ps1 # Windows CMake 构建脚本
├── output/ # 编译产物
│ ├── Mac/
│ ├── Linux/
│ └── Windows/
└── CMakeLists.txt # CMake 配置
Q: 找不到 OpenSSL
# 指定 OpenSSL 路径
-DOPENSSL_ROOT_DIR=$(brew --prefix openssl@3)Q: 架构不匹配(arm64 vs x86_64)
修改 CMakeLists.txt 和 demo/CMakeLists.txt 中的架构参数:
# ARM Mac(默认)
set(CMAKE_CXX_FLAGS "-arch arm64 -std=c++17 ...")
# Intel Mac
set(CMAKE_CXX_FLAGS "-arch x86_64 -std=c++17 ...")Q: 运行时找不到动态库
export DYLD_LIBRARY_PATH="/usr/local/opt/cpprestsdk/lib:/usr/local/opt/protobuf-v28.3/lib:$DYLD_LIBRARY_PATH"Q: 运行时找不到 .so 文件
export LD_LIBRARY_PATH="/usr/local/opt/cpprestsdk/lib:/usr/local/opt/protobuf-v28.3/lib:$LD_LIBRARY_PATH"Q: vcpkg bootstrap 失败
确保安装了 Visual Studio "使用 C++ 的桌面开发"工作负载。
Q: 运行时库不匹配(MT vs MD)
确保 SDK 和 demo 使用相同的 -DCMAKE_MSVC_RUNTIME_LIBRARY 设置。
Q: Protobuf 版本冲突
确保使用 Protobuf 5.28.3,需要 Abseil 和 C++17 支持。Windows 工程已通过 PROTOBUF_USE_DLLS 与 vcpkg DLL 版本保持一致。
Q: 编译警告被当作错误
# 添加编译参数关闭警告
-DCMAKE_CXX_FLAGS="-w"查看 CHANGELOG.md 了解版本更新历史。
Apache License 2.0
如有问题,请通过以下方式联系:
- 提交 GitHub Issue
- 发送邮件至:[email protected]