XAPI统一行情交易接口 377319643
XAPI标准委员会 142703128(需邀请,用于高手进行标准的制定)
##介绍
现在市场上的交易与行情API太多,对每家都接特别麻烦,如果能统一用一套API接入就好了。
如果进行接口的统一,要实现以下几点:
- 统一的结构体
- 统一的调用方式
- 灵活的加载方式
实现统一的结构体必然会有些API的特殊字段没法照顾到;调用方式统一则有些功能将不会实现,而有些功能需要几个请求,或本机模拟的方法来实现;加载方式以前C#层是用的P/Invoke,现在改用LoadLibraryEx/dlopen来实现。
##目录结构
- apis:各种行情交易API的XAPI封装代码
- bin:各项目的编译输出路径
- common:一些通用库
- include:各种头文件,或API的接口
- lib:各种库文件
- languages:各种语言的XAPI封装
- tests:测试代码
- tools:一些小工具。如FakeAPI用来获取CTP/LTS客户端授权码,请看项目中的READEME.md
- 打开AllCppProjects.sln
- common\Queue是每个API封装都依赖它的处理消息队列的库,有64位和32位版。所以在部署时可以放在System32或SysWOW64下。或放在客户端程序的exe同目录下,或放在每个API封装库的同目录下。
- apis\CTP_Quote等一类的项目,是对应的API的封装。编译好后还需要将API官方的库复制到同目录,你可以直接运行CopyApiDll.bat将依赖的dll复制到bin对应的目录下
- 有些项目需要使用到一些授权库的功能common\License,比如说apis\CTP_Trade,直接编译你会发现编译不过,这是因用到的第三方的库文件太大,我在提交代码时提交的是zip。你需要先解压include/cryptopp.zip和lib/cryptlib.zip。你也可在项目属性中去掉ENABLE_LICENSE,这样授权功能模块将不参与编译。具体的方式是,哪个项目编译的时候,报关于randpool.h的错误,就在哪个项目的属性Configuration Properties -> C/C++ -> Preprossor中找到ENABLE_LICENSE,然后去掉它。
languages\CPP\XAPI_CPP,直接编译即可。会生成XAPI_CPP.dll,内置了C和C++两种调用方式。tests\CPP中提供了C++版接口的调用示例。所要用到的头文件是include/XApiCpp.h,它的调用的机制模仿了CTP,使用CXApi和CXSpi.
如想使用C版接口,可参考CXApi与CXSpi是如何实现的,直接使用include/XApiC.h头文件
- 使用Code::Blocks打开*.workspace进行编译,注意得使用Clang编译器,会生成so文件
- 将所有生成的lib*.so文件cp命令复制到/usr/lib下
- 将CTP的两个文件*.so前面加lib复制到/usr/lib下
languages\CSharp\XAPI_CSharp.sln
编译后会生成XAPI_CSharp.dll,这个项目支持COM功能,所以在编译时会进行COM注册。这个注册需要VS以管理员权限运行。如果你不想使用COM功能,也不想切换到管理员进行注册,可以在项目属性页中的Build->Register for COM interop前的勾去了。
编译XAPI_CSharp,有两种输出方式
- 生成XAPI_CSharp.dll,设置输出类型为类库,可以在其它项目中引用
- 生成XAPI_CSharp.exe,设置输出类型为控制台程序,将运行项目中的Program.cs文件,是API的使用示例
实际上是调用的C#版的库,细节请参考languages\MATLAB下的readme.md
其实也是用的C#版的库,注册好后直接到tests\COM下运行示例即可
bin/Debug/x86下会编译一些库,运行CopyApiDll.bat复制一些API官方的库进来,然后再运行clearBin.bat将编译时的一些多余文件清理。在目标机器或客户端下新建XAPI文件夹,将x86文件夹复制到此。注意Queue_x86.dll一定要放在合适的位置,实在搞不清就放在与CTP_Quote_x86.dll这些库在同一个目录下。
- 模仿已经提供的几个项目即可