IPMSG飞鸽传书通信协议.pdf
3页IPMSG飞鸽传书通信协议/********************************************************** *本人(ypxing)根据下面的协议, C语言写的 ipmsg(聊天,文件 /文件夹传输 ) *请参见: **********************************************************/ 最近看到一些朋友在编写网络程序是遇到一些问题,故把以前做 IPMSG时翻 译的文档贴过来, 希望对网络编程新手有所帮助, 在寻找编程项目的同学们也可 参照此文档写出自己的IPMSG 本文只包含其中几个比较重要的命令以及运行机 制的中文翻译,更详细的内容请参照文后的IPMSG 协议英文文档声明:下述协议内容略去了一些在编写程序过程中没有用到协议内容,最初的 Ipmsg协议是用日文写的,下面协议内容由本人(cugb_cat) 翻译自 Mr.Kanazawa 的英文文档本 翻译文档可任意传播和使用 IP信使传输协议 (第 9 版草案 ) 1996/02/21 2003/01/14 修订 H.Shirouzu shirouzu@h.email.ne.jp 关于 IP信使: IP信使使用 TCP/UDP 协议提供收发消息及文件 (目录)。
特性: IP信使能够安装在任何一个安装了TCP/IP协议栈的操作系统上, 使用用 户的动态识别机制,可以和所有用户进行信息交换 运行机制介绍: 使用 TCP/UDP端口(默认端口为 2425),消息的收发使用UDP协议,文件 (文 件夹)的收发使用 TCP 协议 1、命令字: 1) 基本命令字 (32 位命令字的低 8 位) IPMSG_NOOPERATION 不进行任何操作 IPMSG_BR_ENTRY 用户上线 IPMSG_BR_EXIT 用户退出 IPMSG_ANSENTRY 通报 IPMSG_SENDMSG 发送消息 IPMSG_RECVMSG 通报收到消息 IPMSG_GETFILEDATA 请求通过 TCP传输文件 IPMSG_RELEASEFILES 停止接收文件 IPMSG_GETDIRFILES 请求传输文件夹2) 选项位 (32 位命令字的高 24 位) IPMSG_SENDCHECKOPT 传送检查 (需要对方返回确认信息 ) IPMSG_FILEATTACHOPT 传送文件选项 3) 附件类型命令 (文件类型命令字的低8 位) IPMSG_FILE_REGULAR 普通文件 IPMSG_FILE_DIR 目录文件 IPMSG_FILE_RETPARENT 返回上一级目录 2、数据包格式 (使用字符串 ): 1) 数据包格式 (版本 1 的格式 ) 版本号 (1):包编号 :发送者姓名 :发送者主机名 :命令字 :附加信息 2) 举例如下 “1:100:shirouzu:Jupiter:32:Hello” 3、数据包处理总述: 1) 用户识别 当 IPMSG 启动时,命令IPMSG_BR_ENTRY 被广播到网络中,向所有的 用户提示一个新用户的到达(即表示“我来了” );所有用户将把该新上线用 户添 加到自己的用户列表中, 并向该新上线用户发送IPMSG_ANSENTRY命令(即 表示“我” );该新上线用户接收到IPMSG_ANSENTRY 命令后即将用户 添加到自己的用户列表中。
2) 收发消息 使用 IPMSG_SENDMSG 命令发送消息,消息内容添加在附加信息中;在接收 消息时,如果对方要求回信确认(IPMSG_SENDCHECKOPT位打开 ),则需发送 IPMSG_RECVMSG 命令并将对方发送的数据包的编号放在附加信息中一同发送至 发送消息方 3) 附加文件的扩充 (添加于第 9 版) 带有 IPMSG_FILEATTACHOPT位的 IPMSG_SENDMSG 命令可用来传输文件, 文 件属性及内容添加在附加信息中,文件内容添加在消息内容后并以’ \0’与之 分隔开传输文件时以下信息将被添加到消息内容之后(包括格式 ):文件序号 : 文件名 :大小(单位:字节 ):最后修改时间 :文件属性 [: 附加属性 =val1[,val2, ][:附加 信息=, ]]:\a: 文件序号, (文件大小、最后修改时间和文件属性为十六进制数,如果文件名中包含’:’则 使用“ ::”代替 ) 接收端开始接收文件时, 请求传输文件命令IPMSG_GETFILEDATA将发送到发 送端的 TCP端口(和 UDP的发送端口相同 ), 并将发送端发送的包编号:文件序号 : 偏移量 (全为十六进制格式 )写到附加信息区一同发送,文件发送端接收到该请求 信息并进行校验正确后即开始发送文件(不使用任何格式,亦不进行加密 )。
当接收端接收到目录文件时, 将发送附加信息区为发送端发送的包编号:文件 序号:偏移量 (全为十六进制格式 )的 IPMSG_GETDIRFILES命令,以用来请求传输目 录文件; 发送端则将头信息长度 :文件名 :文件大小 :文件属性 :文件内容添加到附加 信息区 (除了 文件名和文件内容外, 其余皆为十六进制 ), 头信息长度是从头信息 长度开始到文件内容前的‘:’分割符为止的字符个数 当文件属性为 IPMSG_FILE_DIR 时,IPMsg能够自动识别其为目录,下一个文 件的数据在该目录之后 当文件属性为 IPMSG_FILE_RETPARENT时, IPMsg识别其动作为返回上一级目录,在这种情况下,文件名为‘.’其属性为当前目录的值。





