: | : | :期货程序化 | :期货程序化研究 | :期货量化学习 | :期货量化 |
返回列表 发帖

CTP期货行情交易API

CTP期货行情交易API

API下载地址:上期所ctp

1、什么是CTP

     综合交易平台(Comprehensive Transaction Platform,CTP)是专门为期货公司开发的一套期货经纪业务管理
系统,由交易、风险控制和结算三大系统组成。
     其中,交易系统主要负责订单处理、行情转发及银期转账业务,结算系统负责交易管理、帐户管理、经纪人
管理、资金管理、费率设置、日终结算、信息查询以及报表管理等,风控系统则主要在盘中进行高速的实时
试算,以及时揭示并控制风险。系统能够同时连通国内四家期货交易所,支持国内商品期货和股指期货的交
易结算业务,并能自动生成、报送保证金监控文件和反洗钱监控文件。
     综合交易平台借鉴代表了国际衍生品领域交易系统先进水平的上期所“新一代交易所系统”的核心技术,采
用创新的完全精确重演的分布式体系架构。
     综合交易平台是基于全内存的交易系统,支持7x24小时连续交易,运维人员不必每日启停系统,可以做到“一
键运维”。该特性使得综合交易平台新增交易中心以扩展业务规模时不用增加运维人力的成本。
     支持FENS机制的“一键切换”多活交易中心也是目前市场上只有CTP系统实现了的特性。该机制使得交易系统
可在某个交易中心宕机的情况下立即切换到另一个备用交易中心,得以实现真真正正的连续交易。
综合交易平台公开并对外开放交易系统接口,使用该接口可以接收交易所的行情数据和执行交易指令。该接
口采用开放接口(API)的方式接入,早已在期货界已经形成事实上的行业标准。
     综合交易平台mini版(CTP mini),是一款速度更快,更轻量级的CTP系统。相对于CTP来说,它追求的是更
小型化的配置,更节约化的资源配备。而用CTP的API开发的客户端程序也可以完美兼容CTP mini系统。

2、用途

     做自己的期货交易软件、自动化交易系统、贴水差价交易、行情数据服务等待。

3、API解析



上期所提供了以上几个头文件,实现相应的方法即可。

(1)行情模块

ThostFtdcMdApi.h

  1. //using namespace std;
  2. class CustomMdSpi: public CThostFtdcMdSpi
  3. {
  4.         // ---- 继承自CTP父类的回调接口并实现 ---- //
  5. public:
  6.         double begintime1;
  7.         double begintime2;
  8.         double begintime3;
  9.         double begintime4;

  10.         double endtime1;
  11.         double endtime2;
  12.         double endtime3;
  13.         double endtime4;

  14.         std::map<std::string, int> gMarket;


  15.         ///当客户端与交易后台建立起通信连接时(还未登录前),该方法被调用。
  16.         void OnFrontConnected();

  17.         ///当客户端与交易后台通信连接断开时,该方法被调用。当发生这个情况后,API会自动重新连接,客户端可不做处理。
  18.         ///@param nReason 错误原因
  19.         ///        0x1001 网络读失败
  20.         ///        0x1002 网络写失败
  21.         ///        0x2001 接收心跳超时
  22.         ///        0x2002 发送心跳失败
  23.         ///        0x2003 收到错误报文
  24.         void OnFrontDisconnected(int nReason);

  25.         ///心跳超时警告。当长时间未收到报文时,该方法被调用。
  26.         ///@param nTimeLapse 距离上次接收报文的时间
  27.         void OnHeartBeatWarning(int nTimeLapse);

  28.         ///登录请求响应
  29.         void OnRspUserLogin(CThostFtdcRspUserLoginField *pRspUserLogin, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  30.         ///登出请求响应
  31.         void OnRspUserLogout(CThostFtdcUserLogoutField *pUserLogout, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  32.         ///错误应答
  33.         void OnRspError(CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  34.         ///订阅行情应答
  35.         void OnRspSubMarketData(CThostFtdcSpecificInstrumentField *pSpecificInstrument, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  36.         ///取消订阅行情应答
  37.         void OnRspUnSubMarketData(CThostFtdcSpecificInstrumentField *pSpecificInstrument, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  38.         ///订阅询价应答
  39.         void OnRspSubForQuoteRsp(CThostFtdcSpecificInstrumentField *pSpecificInstrument, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  40.         ///取消订阅询价应答
  41.         void OnRspUnSubForQuoteRsp(CThostFtdcSpecificInstrumentField *pSpecificInstrument, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  42.         ///深度行情通知
  43.         void OnRtnDepthMarketData(CThostFtdcDepthMarketDataField *pDepthMarketData);

  44.         ///询价通知
  45.         void OnRtnForQuoteRsp(CThostFtdcForQuoteRspField *pForQuoteRsp);
  46. };
复制代码



(2)交易模块

   ThostFtdcTraderApi.h

  1. #pragma once
  2. // ---- 派生的交易类 ---- //
  3. #include "CTP_API/ThostFtdcTraderApi.h"
  4. #include <map>
  5. #include <unordered_map>
  6. #include <string>
  7. #include <algorithm>
  8. #include "iostream"
  9. #include <iostream>
  10. #include <windows.h>
  11. #include <vector>

  12. class CustomTradeSpi : public CThostFtdcTraderSpi
  13. {
  14. // ---- ctp_api部分回调接口 ---- //
  15. public:
  16.         ///当客户端与交易后台建立起通信连接时(还未登录前),该方法被调用。
  17.         void OnFrontConnected();

  18.         ///登录请求响应
  19.         void OnRspUserLogin(CThostFtdcRspUserLoginField *pRspUserLogin, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  20.         ///错误应答
  21.         void OnRspError(CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  22.         ///当客户端与交易后台通信连接断开时,该方法被调用。当发生这个情况后,API会自动重新连接,客户端可不做处理。
  23.         void OnFrontDisconnected(int nReason);

  24.         ///心跳超时警告。当长时间未收到报文时,该方法被调用。
  25.         void OnHeartBeatWarning(int nTimeLapse);

  26.         ///登出请求响应
  27.         void OnRspUserLogout(CThostFtdcUserLogoutField *pUserLogout, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  28.         ///投资者结算结果确认响应
  29.         void OnRspSettlementInfoConfirm(CThostFtdcSettlementInfoConfirmField *pSettlementInfoConfirm, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  30.         ///请求查询合约响应
  31.         void OnRspQryInstrument(CThostFtdcInstrumentField *pInstrument, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  32.         ///请求查询资金账户响应
  33.         void OnRspQryTradingAccount(CThostFtdcTradingAccountField *pTradingAccount, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  34.         ///请求查询投资者持仓响应
  35.         void OnRspQryInvestorPosition(CThostFtdcInvestorPositionField *pInvestorPosition, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  36.         ///报单录入请求响应
  37.         void OnRspOrderInsert(CThostFtdcInputOrderField *pInputOrder, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  38.         ///报单操作请求响应
  39.         void OnRspOrderAction(CThostFtdcInputOrderActionField *pInputOrderAction, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast);

  40.         ///报单通知
  41.         void OnRtnOrder(CThostFtdcOrderField *pOrder);

  42.         ///成交通知
  43.         void OnRtnTrade(CThostFtdcTradeField *pTrade);
  44.        
  45. // ---- 自定义函数 ---- //
  46. public:
  47.         bool loginFlag; // 登陆成功的标识
  48.         // 报单引用
  49.         int iOrderRef;
  50.         int iRequestID;

  51.         // 所有成功订单记录
  52.         std::map<char *, int> tradeOrderRefs;

  53.         //int FRONT_ID;
  54.         //int SESSION_ID;

  55.         void reqOrderInsert(
  56.                 TThostFtdcInstrumentIDType instrumentID,
  57.                 TThostFtdcPriceType price,
  58.                 TThostFtdcVolumeType volume,
  59.                 TThostFtdcDirectionType direction); // 个性化报单录入,外部调用
  60.         //
  61.         int InsertOrder(char *InstrumentID, TThostFtdcDirectionType dir, char offsetFlag, char priceType, double price, int num);
  62.         //
  63.         int DeleteOrder(char *InstrumentID, int orderRef);

  64.         void CallBackCloseOrder(bool flag, int iOrderRef);
  65. private:
  66.         void reqUserLogin(); // 登录请求
  67.         void reqUserLogout(); // 登出请求
  68.         void reqSettlementInfoConfirm(); // 投资者结果确认
  69.         void reqQueryInstrument(); // 请求查询合约
  70.         void reqQueryTradingAccount(); // 请求查询资金帐户
  71.         void reqQueryInvestorPosition(); // 请求查询投资者持仓
  72.         void reqOrderInsert(); // 请求报单录入
  73.        
  74.         void reqOrderAction(CThostFtdcOrderField *pOrder); // 请求报单操作
  75.         bool isErrorRspInfo(CThostFtdcRspInfoField *pRspInfo); // 是否收到错误信息
  76.         bool isMyOrder(CThostFtdcOrderField *pOrder); // 是否我的报单回报
  77.         bool isTradingOrder(CThostFtdcOrderField *pOrder); // 是否正在交易的报单
  78. };
复制代码


论坛官方微信、群(期货热点、量化探讨、开户与绑定实盘)
 
期货论坛 - 版权/免责声明   1.本站发布源码(包括函数、指标、策略等)均属开放源码,用意在于让使用者学习程序化语法撰写,使用者可以任意修改语法內容并调整参数。仅限用于个人学习使用,请勿转载、滥用,严禁私自连接实盘账户交易
  2.本站发布资讯(包括文章、视频、历史记录、教材、评论、资讯、交易方案等)均系转载自网络主流媒体,内容仅为作者当日个人观点,本网转载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。本网不对该类信息或数据做任何保证。不对您构成任何投资建议,不能依靠信息而取代自身独立判断,不对因使用本篇文章所诉信息或观点等导致的损失承担任何责任。
  3.本站发布资源(包括书籍、杂志、文档、软件等)均从互联网搜索而来,仅供个人免费交流学习,不可用作商业用途,本站不对显示的内容承担任何责任。请在下载后24小时内删除。如果喜欢,请购买正版,谢谢合作!
  4.龙听期货论坛原创文章属本网版权作品,转载须注明来源“龙听期货论坛”,违者本网将保留追究其相关法律责任的权力。本论坛除发布原创文章外,亦致力于优秀财经文章的交流分享,部分文章推送时若未能及时与原作者取得联系并涉及版权问题时,请及时联系删除。联系方式:http://www.qhlt.cn/thread-262-1-1.html
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

返回列表