前段时间研究gloox1.0版的注册,用官方自带的example,注册应该是很简单的例子,代码如下:
1: j = new Client( "pc-20110409pvwc" );
2: j->disableRoster();
3: j->registerConnectionListener( this );
4:
5: m_reg = new Registration( j );
6: m_reg->registerRegistrationHandler( this );
7:
8: j->logInstance().registerLogHandler( LogLevelDebug, LogAreaAll, this );
9:
10: j->connect();
11:
12: delete( m_reg );
13: delete( j );但是我用自带的register_example编程成功后运行,在最后一步提交注册信息后返回如下的结果:
“bad-request”。。。仔细看返回的结果,在gloox1.0版本,在register_example运行时候,有Sasl验证过程,跟代码发现进行的是匿名验证。但是我记得在之前0.99版本都不会有验证的过程呀!于是我考虑在注册的时候像之前的版本那样禁用掉Sasl验证,禁用过程用Client::setForceNonSasl函数,代码如下:
1: j = new Client( "pc-20110409pvwc" );
2: j->disableRoster();
3: j->setForceNonSasl();
4: j->registerConnectionListener( this );
5:
6: m_reg = new Registration( j );
7: m_reg->registerRegistrationHandler( this );
8:
9: j->logInstance().registerLogHandler( LogLevelDebug, LogAreaAll, this );
10:
11: j->connect();
12:
13: delete( m_reg );
14: delete( j );修改后运行发现居然还要进行Sasl验证过程,单步调试发现setForceNonSasl没有起作用,找到匿名验证验证的代码处,在Client::handleNormalNode函数中,截取代码段:
1: else if( !m_clientCerts.empty() && !m_clientKey.empty()
2: && m_streamFeatures & SaslMechExternal && m_availableSaslMechs & SaslMechExternal )
3: {
4: notifyStreamEvent( StreamEventAuthentication );
5: startSASL( SaslMechExternal );
6: }
7: #if defined( _WIN32 ) && !defined( __SYMBIAN32__ )
8: else if( m_streamFeatures & SaslMechGssapi && m_availableSaslMechs & SaslMechGssapi )
9: {
10: notifyStreamEvent( StreamEventAuthentication );
11: startSASL( SaslMechGssapi );
12: }
13: else if( m_streamFeatures & SaslMechNTLM && m_availableSaslMechs & SaslMechNTLM )
14: {
15: notifyStreamEvent( StreamEventAuthentication );
16: startSASL( SaslMechNTLM );
17: }
18: #endif
19: else if( m_streamFeatures & SaslMechAnonymous
20: && m_availableSaslMechs & SaslMechAnonymous )
21: {
22: notifyStreamEvent( StreamEventAuthentication );
23: startSASL( SaslMechAnonymous );
24: }
25: else
26: {
27: notifyStreamEvent( StreamEventFinished );
28: connected();
29: }匿名验证是在倒数第二段,于是在它的if判断语句加上检测是否禁止验证如下
else if( !m_forceNonSasl && m_streamFeatures & SaslMechAnonymous
&& m_availableSaslMechs & SaslMechAnonymous )
保存重新编译,这样就可以不用进行匿名验证,实现正常的注册了。
我对gloox1.0理解还很浅,如果哪位知道register_example为什么会运行失败的真正原因,麻烦说明一下!
没有评论:
发表评论