AG Softwate MatrixX中没有响应
本文关键字:响应 Softwate MatrixX AG | 更新日期: 2023-09-27 18:21:13
我正在由AG Softwate MatriX开发IM,我想实现登录操作,但当我使用xmppClient.open()时,我无法接收帮助我接受证书的xml流。
这是我在控制台中发送、接收或输出的xml:
send:<stream:stream xmlns:stream="http://etherx.jabber.org/streams" xmlns="jabber:client" to="dodo.com" version="1.0" >
rec:<stream:stream xmlns:stream="http://etherx.jabber.org/streams" xmlns="jabber:client" id="2543867956" from="dodo.com" version="1.0" xml:lang="en" >
'vivid.vshost.exe' (CLR v4.0.30319: vivid.vshost.exe): Loaded 'C:'Windows'Microsoft.Net'assembly'GAC_MSIL'System.resources'v4.0_4.0.0.0_zh-Hans_b77a5c561934e089'System.resources.dll'. Module was built without symbols.
rec:<stream:features xmlns:stream="http://etherx.jabber.org/streams">
<starttls xmlns="urn:ietf:params:xml:ns:xmpp-tls" />
<mechanisms xmlns="urn:ietf:params:xml:ns:xmpp-sasl">
<mechanism>PLAIN</mechanism>
<mechanism>DIGEST-MD5</mechanism>
<mechanism>SCRAM-SHA-1</mechanism>
</mechanisms>
<c xmlns="http://jabber.org/protocol/caps" hash="sha-1" node="http://www.process-one.net/en/ejabberd/" ver="k0acyvEdZQ7cl5uD5FTPoiOnuaw=" />
<register xmlns="http://jabber.org/features/iq-register" />
</stream:features>
send:<starttls xmlns="urn:ietf:params:xml:ns:xmpp-tls" />
rec:<proceed xmlns="urn:ietf:params:xml:ns:xmpp-tls" />
我不知道为什么我的程序没有发送其余的xml,您可以看到正确的xml流:
SEND: <stream:stream xmlns:stream="http://etherx.jabber.org/streams" xmlns="jabber:client" to="dodo.com" version="1.0" >
RECV: <stream:stream xmlns:stream="http://etherx.jabber.org/streams" xmlns="jabber:client" id="3880372647" from="dodo.com" version="1.0" xml:lang="en" >
RECV: <stream:features xmlns:stream="http://etherx.jabber.org/streams">
<starttls xmlns="urn:ietf:params:xml:ns:xmpp-tls" />
<mechanisms xmlns="urn:ietf:params:xml:ns:xmpp-sasl">
<mechanism>PLAIN</mechanism>
<mechanism>DIGEST-MD5</mechanism>
<mechanism>SCRAM-SHA-1</mechanism>
</mechanisms>
<c xmlns="http://jabber.org/protocol/caps" hash="sha-1" node="http://www.process-one.net/en/ejabberd/" ver="k0acyvEdZQ7cl5uD5FTPoiOnuaw=" />
<register xmlns="http://jabber.org/features/iq-register" />
</stream:features>
SEND: <starttls xmlns="urn:ietf:params:xml:ns:xmpp-tls" />
RECV: <proceed xmlns="urn:ietf:params:xml:ns:xmpp-tls" />
SEND: <stream:stream xmlns:stream="http://etherx.jabber.org/streams" xmlns="jabber:client" to="dodo.com" version="1.0" >
RECV: <stream:stream xmlns:stream="http://etherx.jabber.org/streams" xmlns="jabber:client" id="2091441686" from="dodo.com" version="1.0" xml:lang="en" >
RECV: <stream:features xmlns:stream="http://etherx.jabber.org/streams">
<mechanisms xmlns="urn:ietf:params:xml:ns:xmpp-sasl">
<mechanism>PLAIN</mechanism>
<mechanism>DIGEST-MD5</mechanism>
<mechanism>SCRAM-SHA-1</mechanism>
</mechanisms>
<c xmlns="http://jabber.org/protocol/caps" hash="sha-1" node="http://www.process-one.net/en/ejabberd/" ver="k0acyvEdZQ7cl5uD5FTPoiOnuaw=" />
<register xmlns="http://jabber.org/features/iq-register" />
</stream:features>
SEND: <auth mechanism="SCRAM-SHA-1" xmlns="urn:ietf:params:xml:ns:xmpp-sasl">biwsbj1pbWFjLHI9NmJkdG40NWdGbTNoYWJIR3JpdGdnOUdqT21yUDU0alA=</auth>
RECV: <challenge xmlns="urn:ietf:params:xml:ns:xmpp-sasl">cj02YmR0bjQ1Z0ZtM2hhYkhHcml0Z2c5R2pPbXJQNTRqUGFqRWRPa0hKUGRCczl4aWMxN3lSeXc9PSxzPWowdHhSY0pnY0FaUkdYcnpCMUJydmc9PSxpPTQwOTY=</challenge>
SEND: <response xmlns="urn:ietf:params:xml:ns:xmpp-sasl">Yz1iaXdzLHI9NmJkdG40NWdGbTNoYWJIR3JpdGdnOUdqT21yUDU0alBhakVkT2tISlBkQnM5eGljMTd5Unl3PT0scD0weDZXcFJ1WG0vQzF5a3JIUXA1c2lBS2lpbzA9</response>
RECV: <success xmlns="urn:ietf:params:xml:ns:xmpp-sasl">dj1CRitFMkdhcVZLYlRVeHpLbWxwVG82YVpDZzQ9</success>
SEND: <stream:stream xmlns:stream="http://etherx.jabber.org/streams" xmlns="jabber:client" to="dodo.com" version="1.0" >
RECV: <stream:stream xmlns:stream="http://etherx.jabber.org/streams" xmlns="jabber:client" id="3562760347" from="dodo.com" version="1.0" xml:lang="en" >
RECV: <stream:features xmlns:stream="http://etherx.jabber.org/streams">
<bind xmlns="urn:ietf:params:xml:ns:xmpp-bind" />
<session xmlns="urn:ietf:params:xml:ns:xmpp-session" />
<sm xmlns="urn:xmpp:sm:2" />
<sm xmlns="urn:xmpp:sm:3" />
<c xmlns="http://jabber.org/protocol/caps" hash="sha-1" node="http://www.process-one.net/en/ejabberd/" ver="k0acyvEdZQ7cl5uD5FTPoiOnuaw=" />
<register xmlns="http://jabber.org/features/iq-register" />
</stream:features>
SEND: <iq id="MX_1" type="set" xmlns="jabber:client">
<bind xmlns="urn:ietf:params:xml:ns:xmpp-bind">
<resource>MatriX</resource>
</bind>
</iq>
RECV: <iq id="MX_1" type="result" xmlns="jabber:client">
<bind xmlns="urn:ietf:params:xml:ns:xmpp-bind">
<jid>imac@dodo.com/MatriX</jid>
</bind>
</iq>
SEND: <iq id="MX_2" type="set" xmlns="jabber:client">
<session xmlns="urn:ietf:params:xml:ns:xmpp-session" />
</iq>
RECV: <iq type="result" id="MX_2" xmlns="jabber:client" />
SEND: <iq id="MX_3" type="get" xmlns="jabber:client">
<query xmlns="jabber:iq:roster" />
</iq>
RECV: <iq from="imac@dodo.com" to="imac@dodo.com/MatriX" id="MX_3" type="result" xmlns="jabber:client">
<query xmlns="jabber:iq:roster">
<item subscription="both" jid="test2@dodo.com">
<group>EveryBody</group>
</item>
<item subscription="both" jid="123456@dodo.com">
<group>EveryBody</group>
</item>
<item subscription="both" jid="macbook@dodo.com">
<group>EveryBody</group>
</item>
<item subscription="both" jid="123457@dodo.com">
<group>EveryBody</group>
</item>
<item subscription="both" jid="test3@dodo.com">
<group>EveryBody</group>
</item>
<item subscription="both" jid="admin@dodo.com">
<group>EveryBody</group>
</item>
<item subscription="both" jid="test4@dodo.com">
<group>EveryBody</group>
</item>
<item subscription="both" jid="yj@dodo.com">
<group>EveryBody</group>
</item>
<item subscription="both" jid="test@dodo.com">
<group>EveryBody</group>
</item>
<item subscription="both" jid="yuanjiong@dodo.com">
<group>EveryBody</group>
</item>
<item subscription="both" jid="taojiaen@dodo.com" />
<item ask="subscribe" subscription="none" jid="taojiaen@163.com" />
</query>
</iq>
SEND: <presence xmlns="jabber:client">
<status></status>
<priority>0</priority>
</presence>
RECV: <presence from="imac@dodo.com/MatriX" to="imac@dodo.com/MatriX" xmlns="jabber:client">
<status />
<priority>0</priority>
</presence>
正如您所看到的,我失去了很多流,因为我的程序没有发送正确的xml请帮我找到这个bug
这是我的代码:
Config.NowXmppClient = new XmppClient();
Config.NowXmppClient.ResolveSrvRecords = false;
Config.NowXmppClient.SetXmppDomain("dodo.com");
Config.NowXmppClient.Hostname = "123.456.789s.130";
Config.NowXmppClient.Port= 5222;
const string LIC = @"eJxkkN1SgzAQhV+l470GHLXF2WZEpS2lYv+o08sIMUITAiGxwNPb2vp/s7O7
357dMwuTNKZ5RTu14HnVPyHstJIveksUveYHdIJhqmRiYu0neKFNkkpA3x2Y
GZLrVDfYBvSVw52ptBRUYQiJoNh7I9wQLRWgjxrupChI3nyCVOadoxVAnww8
QVKOK8JpdfPD2VmyGzqw3fDXoahIiKZeXaSK3u8yfG7Zl5ZjOYD+IfCreyok
1srsdh0L2Mff+gvb2uv/AFikLCfaKIq35cOwPb/yeMzasW8PMgcNuugqKpdW
MvBcq5mVt2vCellMrWw+Cdcuvy2WZIOcyaj2h342DcLQsdeBiJpX/mAHw17j
luEsImbKFs9hN2rV8Ok1HhdSsMA1o27LWW81mjxS/+V5U69UvSAoq5mTuyNn
Gyg2d8vHplHzrvZNQthyI9SgzcdP2z6gb9+A7wI=";
Matrix.License.LicenseManager.SetLicense(LIC);
Config.NowXmppClient.OnReceiveXml += new System.EventHandler<Matrix.TextEventArgs>(this.xmppClient_OnReceiveXml);
Config.NowXmppClient.OnSendXml += new System.EventHandler<Matrix.TextEventArgs>(this.xmppClient_OnSendXml);
//Config.NowXmppClient.OnStreamError += new System.EventHandler<Matrix.StreamErrorEventArgs>(this.xmppClient_OnStreamError);
Config.NowXmppClient.OnValidateCertificate += new System.EventHandler<Matrix.CertificateEventArgs>(this.xmppClient_OnValidateCertificate);
Config.NowXmppClient.OnLogin += new System.EventHandler<Matrix.EventArgs>(this.xmppClient_OnLogin);
private void xmppClient_OnValidateCertificate(object sender, CertificateEventArgs e)
{
// always accept cert
e.AcceptCertificate = true;
StackFrame[] stacks = new StackTrace().GetFrames();
Console.Write(ToString(stacks));
// or let the user validate the certificate
// ValidateCertificate(e);
}
private void xmppClient_OnLogin(object sender, Matrix.EventArgs e)
{
Console.WriteLine("OnLogin");
}
private void xmppClient_OnReceiveXml(object sender, TextEventArgs e)
{
Console.WriteLine("rec:" + e.Text);
}
private void xmppClient_OnSendXml(object sender, TextEventArgs e)
{
Console.WriteLine("send:" + e.Text);
}
任何人都可以帮忙
您的TLS服务器证书似乎有问题。尝试安装正确的服务器证书或尝试在没有TLS 的情况下连接
Config.NowXmppClient.StartTls = false;