c# (Quickfixn) 中不正确的 BeginString (FIX.4.4)

Incorrect BeginString (FIX.4.4) in c# (Quickfixn)

我正在尝试从修复中获取 MarketData,但我似乎在回答“不正确的 BeginString (FIX.4.4)”。 “登录”returns确定。但是当我调用 MarketDataRequest 时它不起作用。我检查了我的 XML 字典,它被设置为 FIX.4.4.

quickfix C+ Incorrect BeginString with FIXT.1.1 and FIX.5.0 - FIX.5.0SP2

我看到一个像我的 post 但我的字典 xml 被声明为 FIX.4.4 并且“LOGON”也在工作。 所以,我认为与上面的 link 不同。

这是日志。

2020-11-10 17:27:44,148 [1] INFO  QuickFixDemo.Program OnCreate FIX.4.4:xxxxxxxxxxxxxxxx->XXXXXX
2020-11-10 17:27:46,321 [8] INFO  QuickFixDemo.Program ToAdmin 8=FIX.4.4|9=83|35=A|34=1|49=xxxxxxxxxxxxxxxx|52=20201110-08:27:46.309|56=XXXXXX|98=0|108=20|141=Y|10=112|
2020-11-10 17:27:46,666 [8] INFO  QuickFixDemo.Program FromAdmin 8=FIX.4.4|9=83|35=A|34=1|49=XXXXXX|52=20201110-08:27:46.437|56=xxxxxxxxxxxxxxxx|98=0|108=20|141=Y|10=114|
2020-11-10 17:27:46,681 [8] INFO  QuickFixDemo.Program OnLogon
2020-11-10 17:27:46,686 [8] INFO  QuickFixDemo.Program ToApp 8=FIX.4.4|9=126|35=V|34=2|49=xxxxxxxxxxxxxxxx|52=20201110-08:27:46.685|56=XXXXXX|262=0|263=1|264=0|265=0|146=1|48=4004|22=8|267=2|269=1|269=0|10=033|
2020-11-10 17:27:47,093 [8] INFO  QuickFixDemo.Program ToAdmin 8=FIX.4.4|9=100|35=5|34=3|49=xxxxxxxxxxxxxxxx|52=20201110-08:27:47.093|56=XXXXXX|58=Incorrect BeginString (FIX.4.4)|10=052|
2020-11-10 17:27:47,405 [8] INFO  QuickFixDemo.Program FromAdmin 8=FIX.4.4|9=65|35=5|34=3|49=XXXXXX|52=20201110-08:27:47.187|56=xxxxxxxxxxxxxxxx|10=038|
2020-11-10 17:27:47,426 [8] INFO  QuickFixDemo.Program OnLogout

我的 header 字典看起来像这样

<?xml version="1.0" encoding="UTF-8"?>

<fix major="4" minor="4" servicepack="0" type="FIX">
  <header>
    <field name="BeginString" required="Y"/>
    <field name="BodyLength" required="Y"/>
    <field name="MsgType" required="Y"/>
    <field name="SenderCompID" required="Y"/>
    <field name="TargetCompID" required="Y"/>
    <field name="MsgSeqNum" required="Y"/>
    <field name="PossDupFlag" required="N"/>
    <field name="PossResend" required="N"/>
    <field name="SendingTime" required="Y"/>
    <field name="OrigSendingTime" required="N"/>
  </header>

我的 MarketDataRequest 是这样的:

<message name="MarketDataRequest" msgcat="app" msgtype="V">
  <field name="MDReqID" required="Y"/>
  <field name="SubscriptionRequestType" required="Y"/>
  <field name="MarketDepth" required="Y"/>
  <field name="MDUpdateType" required="N"/>
  <field name="AggregatedBook" required="N"/>
  <component name="MDReqGrp" required="Y"/>
  <component name="InstrmtMDReqGrp" required="Y"/>
</message>

我的配置

[DEFAULT]
BeginString=FIX.4.4
ConnectionType=initiator
ReconnectInterval=10
FileStorePath=store
FileLogPath=log
StartTime=00:00:00
EndTime=00:00:00
UseDataDictionary=Y
DataDictionary=./Fix/LMAX.xml
SocketConnectHost=fix-marketdata.london-demo.lmax.com
SocketConnectPort=443
SSLEnable=Y
SSLValidateCertificates=N
HeartBtInt=20

[SESSION]
# inherit ConnectionType, ReconnectInterval and SenderCompID from default
SenderCompID=XXXXXXXXXXX
TargetCompID=LMXBDM
Username=XXXXXXXXXXXXXXXXXXXXX
Password=XXXXXXXXXXXXXXXX
ResetOnLogon=Y

---------------- 补充信息 2020/11/11

我调试了 quickfix 并找到了返回“UnsupportedVersion exception”的地方。按照我的调试器的图像。

DefaultMessageFactory 的“this._factories”为空。然后这个 class returns 对我来说是 UnsupportedVersion ...我正在研究这个原因。你有什么建议吗?

问题是 linux Directory.GetFiles 区分大小写,因此 DefaultMessageFactory:LoadLocalDlls() 无法在 Linux 中找到本地 dll。我在 github https://github.com/connamara/quickfixn/pull/663 中创建了 pull request 并且通过此更改它在 Linux.

中完美运行