天天看點

【轉貼收藏】MSN協定中文釋義(Zz)

MSN协议中文释义(Zz)

我们可以把MSN的工作机制分成两个阶段:

认证阶段

认证阶段包括登陆到MSN即时通的服务器并且取得好友列表

即时通讯阶段

即时通讯阶段包括发送/接受进入即时通讯阶段的请求和发送/接受消息。

MSN即时通讯软件的协议是基于ASCII码的协议,用其他话来讲就是所有的命令都必

须是英文的!第一个阶段包括连接到MSN即时通软件的服务器。在这个阶段我们应该连接

到服务器“messenger.hotmail.com”的1863端口(MSN即时通讯软件通过1863端口进行工作)。一旦连接上以后,我们就应该开始登陆过程了。此过程的第一步是验证MSN的版本。在此步中,客户端(即你的MSN软件)列出及向服务器发送它可以支持的版本,然后等待服务器的回应。

VER 0 MSNP7 MSNP6 MSNP5 MSNP4 CVRO

在MSN协议中,伴随着每个命令都有一个“试验ID”被发送。此实验ID从0开始,并且当每次服务器成功的对客户端的命令做回应时,都会增加。

服务器的回应如下

VER 0 MSNP7 MSNP6 MSNP5 MSNP4

现在客户端(MSN)和服务器之间确定了它们之间将要进行通讯的版本。

下一步客户端(MSN)向服务器发送一个请求,要求服务器提供它所支持的认证时需要的安全包的名字。

INF 1

不像ahoo,Rediff和其它的一些即时通讯软件,MSN在发送密码时会将密码加密,保证如有人监控你的端口时,密码不会轻易的泄露。

服务器的回应如下

INF 1 MD5 (MD5在这里是服务器当前支持的安全包的名字)

下一步客户端(MSN)将向服务器发送用户ID

USR 2 MD5 I [email protected]

然后服务器将检验它是否包含有验证所需的此用户的所有相关信息。如没有的话,服务器将会发送如下回应:

XFR 2 NS 64.4.13.55:1863 0

意思为客户端(MSN)应该连接到NOTIFICATION服务器,地址和端口分别为64.4.13.55,1863.

我们关闭当前的连接并且在连接到新的服务器64.4.13.55时重复以下步骤

(客户端)VER 3 MSNP7 MSNP6 MSNP5 MSNP4 CVRO

(服务器)VER 3 MSNP7 MSNP6 MSNP5 MSNP4

(客户端)INF 4

(服务器)INF 4 MD5

(客户端)USR 5 MD5 I [email protected]

现在我们连接上的服务器有了此尝试登陆的用户的信息.服务器回应如下:

USR 5 MD5 S 989048851.185113730

服务器发送的此字符串是“MD5 杂乱信息”.此杂乱信息由服务器创建并且在认证过程中使用.客户端然后向服务器发送使用MD5运算法加密后的密码.实际上客户端向服务器发送的是一个独一无二的MD5字符串,此字符串等价于此“MD5杂乱信息”(即989048851.185113730)+密码.结果如下

3b7926d277068ec49576a0c40598ff21

USR 6 MD5 S 3b7926d277068ec49576a0c40598ff21

如果密码正确,服务器将做如下回应:

USR 6 OK [email protected] venkat

此处“venkat”是用户的呢称.

在此协议的最新版本中,服务器将发送一些附加的数据,像用户的信息和一个认证码(类似于一个cookie,可以用到许多其它的功能中)

MSG Hotmail Hotmail 362

MIME-Version:1.0

Content-Type:text/x-msmsgspro file;charset=UT

Login Time:1011252477

EmailEnabled:1

MemberIDHigh:84736

MemberIDLow:-143472939

Lang_preference:103

PreferredEmail:[email protected]

Country:IN

PostalCode:

Gender:M

Kid

Age:22

Sid:517

Kv:2

MSPAuth:2AAAAAAAADU0p4uxxxJtDJozJS1UTS0i7YpwnCoPUHRv56YKxxxCTWmg$$

现在我们登陆上了服务器,但是我们的状态仍然是离线.为了能够发送和接受信息,我们需要把我们的状态改成在线.客户端通过如下命令完成这步:

CHG 7 NLN

服务器则向客户端发送回在线的好友及其相应的状态.

ILN 7 NLN [email protected] nick (NLN:Now online 即当前在线)

ILN 7 AWY [email protected] mike (AWY:Away 即离开)

ILN 7 BSY [email protected] jerry (BSY:Busy 即忙碌)

MSG Hotmail Hotmail 223

MIME-Version:1.0

Content-Type:text/x-msmsgsinitialemailnotification;charset=UTF-8

Inbox-Unread:293

Folders-Unread

Inbox-URL:/cgi-bin/HoTMaiL

Folders-URL:/cgi-bin/folders

Post-URL:http://www.hotmail.com

向服务器发送的下一个命令是和当前使用的客户端的版本相关的.客户端向服务器发送它的版本号和所在机器的信息像*作系统和其配置等

CVR 8 0x0409 win 4.10 i386 MSMSGS 4.5.0127 MSMSGS

0x0409 win4.10 i386 指出客户端当前的运行环境是win98,使用的是Intel的微处理器.

MSMSGS 4.5.0127 MSMSGS 指出msmsgs.exe的版本号

服务器回应提供下载最新版本及一些其它的信息的地址/

CVR 8 4.5.0127 4.5.0127 1.0.0863

http://download.microsoft.com/do ... /en-us/mmssetup.exe

http://messenger.microsoft.com

这个CVR命令的发送并不是必须的,无论此命令是否发送,MSN协议都可以正确的工作.

为了获得我们的好友列表,我们可以发送如下命令

LST 9 RL

服务器将相应发送回“反向列表”,此反向列表为当你在线时,可以看到你并能向你发送即时消息的用户列表.你也可以使用 LST 9 FL命令向服务器请求“正向列表”.此正向列表包括你加入到好友列表中的所有好友.服务器所做的回应如下

LST 9 RL 69 1 19 [email protected] venkat

LST 9 RL 69 2 19 [email protected] puja

LST 9 RL 69 3 19 [email protected] ramachandran

LST 9 RL 69 4 19 [email protected] chandramouli

LST 9 RL 69 6 19 [email protected] Narakatesh

………………….

LST 9 RL 69 19 19 [email protected] puneet

*一旦有好友上线时,服务器(NS)将向我们发送如下命令

NLN 10 NLN [email protected] Venkatesh

相反,如果有好友下线时,服务器将向我们发送如下命令

FLN 10 FLN [email protected] Venkatesh

在MSNP7中,MSN引入了一个新的口令认证机制.MSN服务器向用户发送一个口令钥,用户必须正确的认证此口令钥才能使此过程继续进行下去.

CHL 0 20881396011366812350

客户端必须向服务器发送一MD5,此MD5为以上的“杂乱信息”后附加上字符串“Q1P7W2E4J9R8U3S5”.因此最终向服务器发送的MD5字符串为

20881396011366812350Q1P7W2E4J9R8U3S5

因此客户端的回应如下

QRY 18 [email protected] 32

0212eaad0876afb8505859ca75d21a78

此处18为实验ID,用你的实际实验ID代替18.

如果认证正确,服务器将做出如下回应

QRY 18

在MSN里的即时通讯是基于session的。想进行对话的两个人必须在session模式当中。除非我们同其他用户开始一个聊天session,否则我们是不能发送/接受信息的。

基本上有两种途径可以使一个用户处于一个聊天session中

.1 用户向另一个用户发送一个聊天session请求

2 用户接收从另一个用户那里发送来的聊天session请求

接下来将分别详细介绍这两种途径

用户向另一个用户发送一个聊天session请求

客户端(用户)向服务器发送一个命令,以获取接线总机(SwitchBoard)服务器的地址.所有的即时通讯交谈都必须通过接线总机服务器实现。

XFR9 SB

此接线总机服务器返回此服务器的ip地址,连接端口,和一个CKI杂列。CKI 是一个安全包,用户必须使用此CKI杂列连接上接线总机服务器。

XFR9 SB 64.4.13.88:1863 CKI1989487642.2070896604

现在这次我们将向接线总机服务器进行一次新的连接。而且我们上次对MSN即时通服务器的连接必须要保持,否则我们将会登出。

在我们连接上接线总机服务器之后,我们将向此接线总机服务器发送以下命令:

USR 1 [email protected] 989487642.2070896604

如果我们发送的这个CKI杂列正确的话,接线服务器将会返回

USR 1 OK [email protected] venkat

当以上做完之后,接下来这个用户要做的就是要把另一个用户”叫到”此聊天session中了,这可以通过发送下面的命令完成

CAL 2 [email protected]

服务器将会向此用户回应一个session号,同时也会将此session号发送给另一个用户。

如果另一个用户准备好聊天,并向做出回应时,服务器将向我们发送如下命令

JOI [email protected] Venkatesh

这条命令表示另一个用户加入了聊天当中,我们现在可以接受和发送信息了

用户接收从另一个用户那里发送来的聊天session请求

当我们被一个用户邀请到一个聊天session中时,认证服务器将向我们发送如下的信息.

RNG 11742066 64.4.13.74:1863 CKI 989495494.750408580 [email protected] Venkatesh

上面的命令包含了session号,接线服务器的ip地址,端口,CKI杂列及向我们发出交谈请求的用户信息。

现在我们将向接线服务器进行一次新的连接。同样我们上次对MSN即时通服务器的连接必须要保持,否则我们将会登出。

我们连接上接线服务器,并且发送如下命令

ANS 1 [email protected] 989495494.750408580 11742066

上面的命令包含了我们的登陆名,我们接收到的CKI杂列和session号.

服务器将回应如下信息

IRO 1 1 1 [email protected] Venkatesh 和 ANS 1 OK

我们现在就可以发送和接收信息了。

在我们发送和接收信息之前,让我们了解一下信息是如何创建的

我们发送信息时,将首先建立一个头信息如下所示

MIME-Version: 1.0

Content-Type: text/plain; charset=UTF-8

X-MMS-IM-Format: FN=Microsoft%20Sans%20Serif; EF=; CO=0; CS=0; PF=22

然后使用如下的方式发送

MSG2 N137 MIME-Version: 1.0

Content-Type: text/plain; charset=UTF-8

X-MMS-IM-Format: FN=Microsoft%20Sans%20Serif; EF=; CO=0; CS=0; PF=22

hello

其中2是测试号,我们每发送一次信息,此号就会随着增加。137是指我们发送信息的长度。在上面的例子中就是头信息和我们发送的信息”hello”的长度。

我们发送的信息和上面的例子是差不多的。

下面是我们接受到的一个信息的例子

MSG [email protected] Venkatesh 137

MIME-Version: 1.0

Content-Type: text/plain; charset=UTF-8

X-MMS-IM-Format: FN=Microsoft%20Sans%20Serif; EF=; CO=0; CS=0; PF=22

hello

当另一用户正在输入信息时,我们会收到如下信息

MSG [email protected] Venkatesh 100

MIME-Version: 1.0

Content-Type: text/x-msmsgscontrol

TypingUser: [email protected]

我猜你们对如何编写出自己的MSN即时通讯软件已经有了大致的了解。我将会在以后对MSN的通讯协议继续进行补充,增添一些附加的功能比如增加/删除拥护,重命名,文件传输及语音聊天。

Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=321198

繼續閱讀