[发明专利]统一消息发送、处理方法及装置有效
申请号: | 201711213008.6 | 申请日: | 2017-11-28 |
公开(公告)号: | CN108173807B | 公开(公告)日: | 2021-12-03 |
发明(设计)人: | 王振兴;陈正超 | 申请(专利权)人: | 贵阳语玩科技有限公司 |
主分类号: | H04L29/06 | 分类号: | H04L29/06;H04L29/08 |
代理公司: | 暂无信息 | 代理人: | 暂无信息 |
地址: | 550022 贵州省贵阳市国家高*** | 国省代码: | 贵州;52 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | 本发明公开了一种统一消息发送、处理方法及装置。在上述方法中,接收来自于一个或多个业务服务器的业务消息;将所述业务消息统一封装成统一消息,其中,封装后的统一消息包括:统一消息标识符、消息接收方标识、上一条消息的序列号、当前消息的序列号、业务消息内容;将封装后的统一消息发送至消息接收方。根据本发明的技术方案,消息发送方将所述业务消息统一封装成统一消息,然后将封装后的统一消息发送至消息接收方,需要新增业务消息时,只需要在业务服务器上定义业务消息格式,在客户端上定位业务处理的业务响应函数就可以了,因此简化了操作过程,而且能够保证客户端不会重复处理业务消息。 | ||
搜索关键词: | 统一 消息 发送 处理 方法 装置 | ||
接收来自于一个或多个业务服务器的业务消息;
将所述业务消息统一封装成统一消息,其中,封装后的统一消息包括:统一消息标识符、消息接收方标识、上一条消息的序列号、当前消息的序列号、业务消息内容;
将封装后的统一消息发送至消息接收方。
2.根据权利要求1所述的方法,其特征在于,封装后的统一消息还包括::消息回复步长。3.一种统一消息处理方法,其特征在于,包括:消息接收方接收封装后的统一消息,其中,所述封装后的统一消息包括:统一消息标识符、消息接收方标识、上一条消息的序列号、当前消息的序列号、业务消息内容;
所述消息接收方判断所述统一消息中的当前消息的序列号与当前接收到的消息最大序列号的大小;
所述消息接收方当所述当前消息的序列号大于所述消息最大序列号时,判断所述上一条消息的序列号与当前接收到的消息最大序列号的大小;
当所述上一条消息的序列号与当前接收到的消息最大序列号相等时,所述消息接收方将所述业务消息内容传送至客户端应用层执行业务消息处理,并将当前接收到的消息数量增加1。
4.根据权利要求3所述的方法,其特征在于,所述消息接收方判断所述统一消息中的当前消息的序列号与当前接收到的消息最大序列号的大小之后,还包括:当所述当前消息的序列号小于或等于所述消息最大序列号时,所述消息接收方确定之前接收过所述当前消息,丢弃所述当前消息;
所述消息接收方将当前接收到的消息数量增加1。
5.根据权利要求3或4所述的方法,其特征在于,所述封装后的统一消息还包括:消息回复步长,则所述消息接收方将当前接收到的消息数量增加1之后,还包括:所述消息接收方判断所述当前接收到的消息数量与所述消息回复步长的大小;
当所述当前接收到的消息数量大于或等于所述消息回复步长时,所述消息接收方向所述消息发送方发送回复包,其中,所述回复包携带有所述当前接收到的消息最大序列号,以使所述消息发送方删除暂存的小于或者等于所述当前接收到的消息最大序列号的消息序列号对应的消息。
6.根据权利要求3所述的方法,其特征在于,判断所述上一条消息的序列号与当前接收到的消息最大序列号的大小之后,还包括以下之一:当所述上一条消息的序列号小于当前接收到的消息最大序列号时,所述消息接收方丢弃所述当前消息;
当所述上一条消息的序列号大于当前接收到的消息最大序列号时,所述消息接收方确定当前接收到的消息中有遗漏的消息,丢弃所述当前消息,向所述消息发送方发送回复包,其中,所述回复包携带有所述当前接收到的消息最大序列号,以请求所述消息发送方重新发送该消息最大序列号之后的一个或多个序列号所对应的消息。
7.根据权利要求3所述的方法,其特征在于,还包括:在消息接收方登录后,在底层设置已接收到的当前接收到的消息最大序列号;
向所述消息发送方发送回复包,其中,所述回复包携带有所述当前接收到的消息最大序列号,以与消息发送方进行消息同步。
8.一种统一消息发送装置,其特征在于,包括:第一接收模块,用于接收来自于一个或多个业务服务器的业务消息;
封装模块,用于将所述业务消息统一封装成统一消息,其中,封装后的统一消息包括:统一消息标识符、消息接收方标识、上一条消息的序列号、当前消息的序列号、业务消息内容;
发送模块,用于将封装后的统一消息发送至消息接收方。
9.一种统一消息处理装置,其特征在于,包括:第二接收模块,用于接收封装后的统一消息,其中,所述封装后的统一消息包括:统一消息标识符、消息接收方标识、上一条消息的序列号、当前消息的序列号、业务消息内容;
第一判断模块,用于判断所述统一消息中的当前消息的序列号与当前接收到的消息最大序列号的大小;
第二判断模块,用于当所述当前消息的序列号大于所述消息最大序列号时,判断所述上一条消息的序列号与当前接收到的消息最大序列号的大小;
第一处理模块,用于当所述上一条消息的序列号与当前接收到的消息最大序列号相等时,将所述业务消息内容传送至客户端应用层执行业务消息处理,并将当前接收到的消息数量增加1。
10.根据权利要求9所述的装置,其特征在于,还包括以下之一:第二处理模块,用于当所述当前消息的序列号小于或等于所述消息最大序列号时,确定之前接收过所述当前消息,丢弃所述当前消息,将当前接收到的消息数量增加1;
第三处理模块,用于当所述上一条消息的序列号小于当前接收到的消息最大序列号时,所述消息接收方丢弃所述当前消息;
第四处理模块,用于当所述上一条消息的序列号大于当前接收到的消息最大序列号时,所述消息接收方确定当前接收到的消息中有遗漏的消息,丢弃所述当前消息,向所述消息发送方发送回复包,其中,所述回复包携带有所述当前接收到的消息最大序列号,以请求所述消息发送方重新发送该消息最大序列号之后的一个或多个序列号所对应的消息。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于贵阳语玩科技有限公司,未经贵阳语玩科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/patent/201711213008.6/,转载请声明来源钻瓜专利网。