re: gloox代碼分析3 - 注冊模塊 ysong.lee 2008-11-18 13:01
1. 我對gloox進行了修改,client_->setHeaderTo(HEADERTO); 是自己添加的方法,目的是為了fix gloox不能連接到gtalk server的問題,通過修改,可以自己控制ClientBase::header()方法中在發送hello信息時候的to屬性,這在服務器是gtalk server的時候是有用的,如果我們的服務器地址設置為talk.google.com,則header()方法默認to="talk.google.com",這是錯誤的,應該為to="gmail.com".
2. sasl failed。登陸的時候需要sasl 驗證,如果服務器為gtalk server, 當你接收到服務器發送的以下信息的時候
(Server -> Client)
<stream:features>
<mechanisms xmlns="urn:ietf:params:xml:ns:xmpp-sasl">
<mechanism>PLAIN</mechanism>
<mechanism>X-GOOGLE-TOKEN</mechanism>
</mechanisms>
</stream:features>
需要進行sasl驗證,發送的驗證數據格式為:
'\0'+username+'\0'+password 的base64編碼, username和password必須是經過認證的.
例如:
'\0' + 'ysong.lee@gmail.com' + '\0' + 123456 -> 經過base64編碼處理
(Client -> Server)
<auth xmlns="urn:ietf:params:xml:ns:xmpp-sasl" mechanism="PLAIN">
AHlzb25nLmxlZUBnbWFpbC5jb20AeXNvbmdAMTk4NA==
</auth>
3. 如果還有疑問,可以參考我的另外一篇文章“如何利用jabber協議與gtalk服務器通訊 - 建立會話”,里面詳細描述了如何登陸到gtalk服務器.
4. 做XMPP的程序,仔細閱讀從server到client和client的server的xml數據流,并參考標準協議,問題都可以解決:), 還有問題可以發email給我.
@ly