CN110096379B - 基于通用协议的消息分发方法、装置、设备及存储介质 - Google Patents
基于通用协议的消息分发方法、装置、设备及存储介质 Download PDFInfo
- Publication number
- CN110096379B CN110096379B CN201910360967.3A CN201910360967A CN110096379B CN 110096379 B CN110096379 B CN 110096379B CN 201910360967 A CN201910360967 A CN 201910360967A CN 110096379 B CN110096379 B CN 110096379B
- Authority
- CN
- China
- Prior art keywords
- message
- distribution
- character string
- target
- function
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/54—Interprogram communication
- G06F9/546—Message passing systems or structures, e.g. queues
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Stored Programmes (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本发明实施例公开了一种基于通用协议的消息分发方法、装置、设备及存储介质。该方法包括:消息分发对象获取待分发消息,并确定待分发消息对应的消息接收对象,其中,消息接收对象基于通用消息分发协议而生成,通用消息分发协议包含通用消息分发函数,通用消息分发函数的输入参数的数据类型为具有目标数据结构的目标字符串类型,目标数据结构中包含预设消息标识字段;消息分发对象将待分发消息转换为目标字符串类型,生成目标分发消息;消息分发对象以目标分发消息为输入参数,调用消息接收对象中的通用消息分发函数,将目标分发消息分发至消息接收对象。通过上述技术方案,实现了不同功能对应的各种消息的直达式分发,提高了代码可维护性。
Description
技术领域
本发明实施例涉及计算机技术,尤其涉及一种基于通用协议的消息分发方法、装置、设备及存储介质。
背景技术
目前,在基于Android系统开发的应用程序中,各种消息的分发方式除了将消息层层传递直至接收消息的目标视图的传统式的消息分发方式之外,还有一种基于专用协议的消息分发方式,其需要构建与消息功能对应的消息直达式传输的专用协议,通过该专用协议将消息直接传输至目标视图。基于专用协议的消息分发方式相对于传统的消息分发方式,能够很大程度上减少消息的传递次数,从而减少消息传输所需的系统资源。
但是基于专用协议的消息分发方式需要针对每种功能设计相应的专用协议,例如,针对弹幕功能设计适合弹幕消息的数据类型的弹幕消息分发协议,针对颜色更新功能设计适合颜色消息的数据类型的颜色消息分发协议,针对进度条更新功能设计适合进度的数据类型的进度消息分发协议等。当消息功能增多时,便需要设计并维护大量的专用协议,无疑会降低代码可维护性。
发明内容
本发明实施例提供一种基于通用协议的消息分发方法、装置、设备及存储介质,以实现不同功能对应的各种消息的直达式分发,提高代码可维护性。
第一方面,本发明实施例提供了一种基于通用协议的消息分发方法,包括:
消息分发对象获取待分发消息,并确定所述待分发消息对应的消息接收对象,其中,所述消息接收对象基于通用消息分发协议而生成,所述通用消息分发协议包含通用消息分发函数,所述通用消息分发函数的输入参数的数据类型为具有目标数据结构的目标字符串类型,所述目标数据结构中包含预设消息标识字段;
所述消息分发对象将所述待分发消息转换为所述目标字符串类型,生成目标分发消息;
所述消息分发对象以所述目标分发消息为输入参数,调用所述消息接收对象中的通用消息分发函数,将所述目标分发消息分发至所述消息接收对象。
第二方面,本发明实施例还提供了一种基于通用协议的消息分发装置,该装置包括:
待分发消息获取模块,配置于消息分发器,用于获取待分发消息,并确定所述待分发消息对应的消息接收对象,其中,所述消息接收对象基于通用消息分发协议而生成,所述通用消息分发协议包含通用消息分发函数,所述通用消息分发函数的输入参数的数据类型为具有目标数据结构的目标字符串类型,所述目标数据结构中包含预设消息标识字段;
目标分发消息生成模块,配置于消息分发器,用于将所述待分发消息转换为所述目标字符串类型,生成目标分发消息;
消息分发模块,配置于消息分发器,用于以所述目标分发消息为输入参数,调用所述消息接收对象中的通用消息分发函数,将所述目标分发消息分发至所述消息接收对象。
第三方面,本发明实施例还提供了一种设备,该设备包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现本发明任意实施例所提供的基于通用协议的消息分发方法。
第四方面,本发明实施例还提供了一种计算机可读存储介质,其上存储有计算机程序,该计算机程序被处理器执行时实现本发明任意实施例所提供的基于通用协议的消息分发方法。
本发明实施例通过预先设计一种能够快速解析消息标识及便于数据流转的通用数据类型,即具有目标数据结构的目标字符串类型,为后续实现不同功能对应的不同数据类型的消息的统一分发提供基础。通过消息分发对象将获取到的待分发消息转换为目标字符串类型,生成目标分发消息,进而通过基于通用消息分发协议而生成的消息接收对象中的通用消息分发函数,将目标分发消息直接传输至消息接收对象,实现了不同功能对应的各种数据类型的消息均基于同一个通用消息分发协议来直达式分发,解决了不同功能的消息分发需要设计不同的分发协议而造成的协议过多和不易维护的问题,提高了应用程序中消息分发的稳定性及程序代码的可维护性。
附图说明
图1是本发明实施例一中的一种基于通用协议的消息分发方法的流程图;
图2是本发明实施例二中的一种基于通用协议的消息分发方法的流程图;
图3是本发明实施例三中的一种基于通用协议的消息分发方法的流程图;
图4是本发明实施例四中的一种基于通用协议的消息分发装置的结构示意图;
图5是本发明实施例五中的一种设备的结构示意图。
具体实施方式
下面结合附图和实施例对本发明作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释本发明,而非对本发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与本发明相关的部分而非全部结构。
实施例一
本实施例提供的基于通用协议的消息分发方法可适用于基于Android平台开发的应用程序内的消息的传输。该方法可以由基于通用协议的消息分发装置来执行,该装置可以由软件和/或硬件的方式实现,该装置可以集成在配置有Android系统的设备中,例如典型的是用户终端设备,例如手机、平板电脑或智能电视等。参见图1,本实施例的方法包括:
S110、消息分发对象获取待分发消息,并确定待分发消息对应的消息接收对象。
其中,消息分发对象是指用于执行消息分发操作的实例化对象。消息接收对象则是指用于接收消息的实例化对象,例如可以是显示消息的视图、处理消息的业务控制器或存储消息的数据管理器等。待分发消息是指需要传输至消息接收对象的消息,其可以是应用程序中不同功能模块对应的消息,例如可以是弹幕消息、颜色变更消息或进度条进度变更消息等。
由于本发明实施例中的消息分发操作是基于协议的直达式分发,故每个需要接收消息的对象(消息接受对象)都应当事先继承用于消息分发的协议,并实现协议内部函数,即消息接收对象基于通用消息分发协议而生成,通用消息分发协议包含通用消息分发函数,通用消息分发函数的输入参数的数据类型为具有目标数据结构的目标字符串类型,目标数据结构中包含预设消息标识字段。其中,通用消息分发协议为预先定义的消息分发的通用性协议,其内至少包含一个用于实现消息分发功能的通用消息分发函数,例如通用消息分发协议的实现示例代码可以为public interface IOnChange{void onChangeState(String msg)},IOnChange为协议名称,onChangeState为通用消息分发函数的函数名称,msg为通用消息分发函数的输入参数,其是一个目标字符串类型的数据。该通用消息分发函数的函数输入参数的数据类型为预先设定的通用数据类型,即具有目标数据结构的目标字符串类型。将通用数据类型设置为字符串类型,是因为其属于一种基础数据类型,能够方便数据快速流转。另外,每种消息都有对应的功能,消息接收对象接收之后需要先识别该消息的类型再执行相应的处理,故在目标数据结构中设置一个存储消息标识的字段(即字符串类型的预设消息标识字段),来存储能够唯一表征一个消息的消息标识。上述目标字符串类型可以是系统提供的通用数据类型,例如Java对象简谱(JavaScript Object Notation,JSON),也可以是自定义的数据类型,只要其满足能够快速解析消息标识(如消息标识字段独立于其他字段)和便于数据流转的特性即可。更优选的是,目标数据结构中的消息标识要便于快速解析,而消息内容则尽量保持原有数据类型,以减少消息接收对象接收消息后的消息二次解析(即转换至消息原本的数据类型)过程,或者采用二次解析过程较为快捷的数据结构。
具体地,消息分发对象从服务器或本地端获取到待分发消息,之后便可以根据待分发消息中的消息标识来确定待分发消息对应的消息接收对象。
S120、消息分发对象将待分发消息转换为目标字符串类型,生成目标分发消息。
具体地,一般同一功能的待分发消息是以同一种数据类型来存储,不同功能的待分发消息以不同的数据类型来存储,那么为了能够将不同功能的待分发消息以通用消息分发协议分发,就需要将待分发消息的数据类型转换为目标字符串类型,数据类型转换后的待分发消息便成为目标分发消息,其可以直接作为通用消息分发函数的输入参数。
S130、消息分发对象以目标分发消息为输入参数,调用消息接收对象中的通用消息分发函数,将目标分发消息分发至消息接收对象。
具体地,消息分发对象生成目标分发消息后,便可以将目标分发消息作为函数输入参数,调用之前确定的消息接收对象中的通用消息分发函数,来将消息分发对象中的目标分发消息传输至消息接收对象,以便消息接收对象解析并处理目标分发消息。
需要说明的是,消息分发对象在访问消息接收对象之前,需要通过某种方式持有各个消息接收对象的引用关系,这样才具有对消息接收对象的访问权限。例如可以将消息接收对象的初始化操作设置在消息分发类的构造函数中,当实例化消息分发对象时便可以同时生成消息接收对象,并具有对其访问权限;也可以预先在消息分发对象中定义一个具有公有权限的对象注册函数,之后在生成消息接收对象后,以该消息接收对象为输入参数,调用该对象注册函数,将该消息接收对象注册至消息分发对象中,使消息分发对象具有该消息接收对象的访问权限。
本实施例的技术方案,通过预先设计一种能够快速解析消息标识及便于数据流转的通用数据类型,即具有目标数据结构的目标字符串类型,为后续实现不同功能对应的不同数据类型的消息的统一分发提供基础。通过消息分发对象将获取到的待分发消息转换为目标字符串类型,生成目标分发消息,进而通过基于通用消息分发协议而生成的消息接收对象中的通用消息分发函数,将目标分发消息直接传输至消息接收对象,实现了不同功能对应的各种数据类型的消息均基于同一个通用消息分发协议来直达式分发,解决了不同功能的消息分发需要设计不同的分发协议而造成的协议过多和不易维护的问题,提高了应用程序中消息分发的稳定性及程序代码的可维护性。
实施例二
本实施例在上述实施例一的基础上,对“目标数据结构”进行了进一步优化。在此基础上,还可以进一步对“将待分发消息转换为目标字符串类型,生成目标分发消息”进行优化。在上述基础上,还可以进一步增加“消息接收对象解析目标分发消息”的步骤。其中与上述各实施例相同或相应的术语的解释在此不再赘述。本实施例中的目标数据结构为Java对象简谱,那么目标字符串类型便为JSON类型。参见图2,本实施例提供的基于通用协议的消息分发方法包括:
S210、消息分发对象获取待分发消息,并确定待分发消息对应的消息接收对象。
S220、消息分发对象以待分发消息对应的初始消息对象为输入参数,调用Java对象简谱对应的抽象对象简谱类的第一类型转换函数,将初始消息对象转换为抽象对象简谱类的对象,生成初始简谱对象。
其中,初始消息对象是承载待分发消息的对象,例如待分发消息是以bean数据结构存储,那么初始消息对象便是一个bean对象。抽象对象简谱类JSONObject是生成Java对象简谱对象(JSON对象)的过渡类,其由Android系统提供。第一类型转换函数是进行数据类型转换的函数,其是抽象对象简谱类的内部函数,用于将其他数据类型转换为抽象对象简谱类的对象(即初始简谱对象)。
具体地,消息分发对象首先将待分发消息对应的初始消息对象(如TestBean)作为函数输入参数,调用抽象对象简谱类JSONObject的第一类型转换函数fromObject(),将初始消息对象转换为初始简谱对象jsObj,即JSONObject jsObj=JSONObject.fromObject(bean)。该初始简谱对象jsObj不仅是生成Java对象简谱对象的中间态,更是为了后续独立设置消息标识的字段,以确保待分发消息的完整性和Java对象简谱对象中消息标识的正确解析。
S230、消息分发对象以预设消息标识字段和待分发消息中的消息标识为输入参数,调用初始简谱对象中的字段添加函数,将预设消息标识字段添加至初始简谱对象,并为预设消息标识字段设置字段值,生成第一过渡简谱对象。
其中,预设消息标识字段是预先设置的消息标识字段,其为字符串string类型,且区别于初始消息对象TestBean中的消息标识字段,例如预设消息标识字段为#msgType,这样便因为bean中的字段信息不能以#开头而与之区分,保证插入字段的可靠性和唯一性。
具体地,消息分发对象以预设消息标识字段#msgType和待分发消息中的消息标识(如XXXA)为函数输入参数,调用初始简谱对象jsObj中的字段添加函数putString(),即jsObj.putString("#msgType","XXXA"),将预设消息标识字段添加至初始简谱对象,并为其赋值,将添加消息标识字段后的初始简谱对象称作第一过渡简谱对象。
S240、消息分发对象调用第一过渡简谱对象中的字符串转换函数,将过渡简谱对象转换为字符串类型的Java对象简谱对象,作为目标分发消息。
具体地,消息分发对象调用第一过渡简谱对象中的字符串转换函数,即jsObj.toString(),将第一过渡简谱对象转换为字符串string类型的对象,即生成了Java对象简谱对象msgJson,将msgJson对象作为目标分发消息。
S250、消息分发对象以目标分发消息为输入参数,调用消息接收对象中的通用消息分发函数,将目标分发消息分发至消息接收对象。
S260、消息接收对象以目标分发消息对应的Java对象简谱对象为输入参数,调用抽象对象简谱类的对象生成函数,将Java对象简谱对象转换为抽象对象简谱类型,生成第二过渡简谱对象。
具体地,消息接收对象接收目标分发消息之后,便以目标分发消息为函数输入参数,调用抽象对象简谱类的对象生成函数,即JSONObject jsObj2=new JSONObject(msgJson),便可将Java对象简谱对象转换成抽象对象简谱JSONObject类型的对象,即第二过渡简谱对象jsObj2。
S270、消息接收对象以预设消息标识字段为输入参数,调用第二过渡简谱对象的字符串获取函数,获得目标分发消息中的消息标识。
具体地,消息接收对象首先要获得待分发消息的消息标识,故以预设消息标识字段#msgType为函数输入参数,调用第二过渡简谱对象的字符串获取函数,即jsObj2.getString("#msgType"),来读取到第二过渡简谱对象中的消息标识,即获得目标分发消息中的消息标识"XXXA"。此时消息接收对象便可以根据消息标识来确定后续需要对目标分发消息执行什么样的处理操作。
S280、消息接收对象以Java对象简谱对象和初始消息对象对应的类类型为输入参数,调用抽象对象简谱类的第二类型转换函数,由Java对象简谱对象生成类类型对应的解析消息对象。
具体地,消息接收对象在对目标分发消息处理之前,需要完全解析出目标分发消息的内容,也就是说还需要对目标分发消息进行二次解析。所谓的二次解析就是将目标分发消息还原到初始消息对象所属的类类型TestBean的过程。例如:以Java对象简谱对象msgJson和初始消息对象对应的类类型TestBean.class为函数输入参数,调用抽象对象简谱类JSONObject的第二类型转换函数parseObject(),生成解析消息对象,即TestBeantestBean=JSONObject.parseObject(msgJson,TestBean.class),这样就将目标分发消息还原到了bean类型的数据。
S290、消息接收对象依据消息标识和解析消息对象,触发执行消息标识对应的消息处理功能。
具体地,消息接收对象根据获得的消息标识来确定针对该消息需要执行的功能(即消息标识对应的消息处理功能),并对解析消息对象执行相应的消息处理功能操作,以完成目标分发消息的处理。
本实施例的技术方案,通过将目标数据结构设置为Java对象简谱JSON,利用了JSON数据能够快捷的进行正向和反向转换的特性,为后续消息的数据类型转换提供了基础,进一步提高了基于通用消息分发协议来统一分发消息的效率。
实施例三
本实施例在上述实施例一的基础上,对“目标数据结构”进行了进一步优化。在此基础上,还可以进一步对“将待分发消息转换为目标字符串类型,生成目标分发消息”进行优化。在上述基础上,还可以进一步增加“消息接收对象解析目标分发消息”的步骤。其中与上述各实施例相同或相应的术语的解释在此不再赘述。
本实施例中目标数据结构包含结构开始符、消息标识键信息、与消息标识键信息对应的消息标识值信息、结构内容分割符、消息内容开始符、消息内容键值对信息及键值对分隔符、消息内容结束符和结构结束符,其中,结构开始符和结构结束符、以及消息内容开始符和消息内容结束符均为成对的字符,且结构开始符、消息内容开始符与目标数据结构中的剩余字符均不同。例如,目标数据结构的定义代码示例为[type:"xxx",{key1:"value1"/key2:"value2"/key3:"value3"/}],其中,“[”和“]”分别是结构开始符和结构结束符,其是目标数据结构的开始标识和结束标识,其为一对字符,且是与目标数据结构中其他字符均不同的字符。type:"xxx"分别为消息标识键信息和消息标识值信息。“,”为结构内容分隔符,其用于分割目标数据结构中的消息标识和消息内容。“{”和“}”分别为消息内容开始符和消息内容结束符,其是消息内容的开始标识和结束标识,也为一对字符,且是与目标数据结构中其他字符均不同的字符。key1:"value1"、key2:"value2"和key3:"value3"分别为消息内容中的3对键值对信息。“/”为键值对分隔符。
参见图3,本实施例提供的基于通用协议的消息分发方法包括:
S310、消息分发对象获取待分发消息,并确定待分发消息对应的消息接收对象。
S320、消息分发对象调用动态字符串类生成动态字符串对象。
具体地,消息分发对象通过动态字符串类StringBuild的构造函数来创建一个动态字符串对象builder,即StringBuild builder=new StringBuild()。
S330、消息分发对象以结构开始符、待分发消息对应的消息标识字段、消息标识字段对应的消息标识、结构内容分割符和消息内容开始符为输入参数,调用动态字符串对象的字符串连接函数,将结构开始符、消息标识字段、消息标识和结构内容分割符添加至动态字符串对象。
具体地,消息分发对象以结构开始符“[”、待分发消息对应的消息标识字段type、消息标识“xxx”、结构内容分割符“,”和消息内容开始符“{”为输入参数,调用动态字符串对象builder的字符串连接函数append(),将“[type:xxx,{”添加至动态字符串对象,即builder.append("[type:xxx,{")。
S340、消息分发对象遍历待分发消息,并分别将每次遍历获得的键值对信息和键值对分隔符为输入参数,调用动态字符串对象的字符串连接函数,将各键值对信息及各键值对分隔符添加至动态字符串对象。
具体地,消息分发对象以循环遍历的方式依次从待分发消息对应的初始消息对象中获取消息中的键信息和该键信息对应的值信息,并调用动态字符串对象builder的字符串连接函数append,将获得的键信息“keyX”、键值对连接符“:”、值信息“valueX”和键值对分隔符“/”添加至动态字符串对象builder,即builder.append("keyX:valueX/"),其中X表示上述中的1、2、3等。
S350、消息分发对象以消息内容结束符和结构结束符为输入参数,调用动态字符串对象的字符串连接函数,将消息内容结束符和结构结束符添加至动态字符串对象。
具体地,待消息内容全部添加至动态字符串对象之后,消息分发对象再次调用动态字符串对象的字符串连接函数,将消息内容结束符和结构结束符添加至动态字符串对象,即builder.append("}]"),至此便完成目标数据结构的构建。
S360、消息分发对象调用动态字符串对象的字符串生成函数,生成目标字符串类型的目标字符串对象,作为目标分发消息。
具体地,消息分发对象调用动态字符串对象builder的字符串生成函数toString(),将上述构建完成的目标数据结构的数据转换为字符串类型,生成目标字符串对象msg,即msg=[type:"xxx",{key1:"value1"/key2:"value2"/key3:"value3"/}],作为目标分发消息。
S370、消息分发对象以目标分发消息为输入参数,调用消息接收对象中的通用消息分发函数,将目标分发消息分发至消息接收对象。
S380、消息接收对象分别调用目标字符串对象的字符串提取函数和字符串分割函数,获得目标字符串对象中的消息标识和各键值对信息,并依据消息标识和各键值对信息,触发执行消息标识对应的消息处理功能。
具体地,消息接收对象接收目标分发消息之后,首先对其进行一次解析,以便获得消息标识。之后可以对其进行消息内容的二次解析,以便获得完整的消息内容。其代码实现示例如下:
String msg1=msg.subString(1,msg.length-1);//通过字符串提取函数subString(),截取msg字符串中去掉“[”和“]”的内容信息,并将得到的信息复制为msg1。
String[]msg2=msg1.split(",");//通过字符串分割函数split(),将msg1根据","进行分割得到一个字符串数组msg2,msg2中的第一个元素内容就是type:"xxx",第二个元素内容就是{key1:"value1"/key2:"value2"/key3:"value3"/}。
String[]msg3=msg2[0].split(":");//通过相同的方式对msg2中第一个元素进行分割,得到msg3,那么msg3中的第一个元素就是type,第二个元素就是xxx了,这样就快速的解析出了消息标识xxx,在没有对目标字符串对象进行完全解析的情况下就能够快速的得到消息标识字段type及其值信息xxx,极大的提高了解析效率。
String msg4=msg2[1].subString(1,msg2[1].length-1);//msg4的内容是(key1:"value1"/key2:"value2"/key3:"value3"/)
String[]msg5=msg4.split("/");//msg5数组中存储的就是多个键值对信息keyX:"valueX"。
然后遍历msg5数组中的所有元素,依次取出其中一个元素,并利用字符串分割函数split(":")对该元素进行分割得到具体的键信息key和值信息value,这样就完成了所有数据的解析工作,从而快速的得到了具体的消息内容信息。
本实施例的技术方案,通过将目标数据结构设计为整体字符串拼接的形式,在便于数据流转的同时,能够一定程度上提高目标分发消息的构建效率和解析效率。通过目标数据结构中将消息标识和消息内容独立起来,能够进一步提高消息标识的解析速度。通过将目标数据结构中的消息内容设置为以某种形式的字符串来存储,而非其他较为复杂的数据结构,能够提高消息二次解析的速度,进而进一步提高基于通用消息分发协议来统一分发消息的效率。
以下是本发明实施例提供的基于通用协议的消息分发装置的实施例,该装置与上述各实施例的基于通用协议的消息分发方法属于同一个发明构思,在基于通用协议的消息分发装置的实施例中未详尽描述的细节内容,可以参考上述基于通用协议的消息分发方法的实施例。
实施例四
本实施例提供一种基于通用协议的消息分发装置,参见图4,该装置具体包括:
待分发消息获取模块410,配置于消息分发器,用于获取待分发消息,并确定待分发消息对应的消息接收对象,其中,消息接收对象基于通用消息分发协议而生成,通用消息分发协议包含通用消息分发函数,通用消息分发函数的输入参数的数据类型为具有目标数据结构的目标字符串类型,目标数据结构中包含预设消息标识字段;
目标分发消息生成模块420,配置于消息分发器,用于将待分发消息转换为目标字符串类型,生成目标分发消息;
消息分发模块430,配置于消息分发器,用于以目标分发消息为输入参数,调用消息接收对象中的通用消息分发函数,将目标分发消息分发至消息接收对象。
可选地,目标数据结构包含结构开始符、消息标识键信息、与消息标识键信息对应的消息标识值信息、结构内容分割符、消息内容开始符、消息内容键值对信息及键值对分隔符、消息内容结束符和结构结束符,其中,结构开始符和结构结束符、以及消息内容开始符和消息内容结束符均为成对的字符,且结构开始符、消息内容开始符与目标数据结构中的剩余字符均不同。
进一步地,目标分发消息生成模块420具体用于:
调用动态字符串类生成动态字符串对象;
以结构开始符、待分发消息对应的消息标识字段、消息标识字段对应的消息标识、结构内容分割符和消息内容开始符为输入参数,调用动态字符串对象的字符串连接函数,将结构开始符、消息标识字段、消息标识和结构内容分割符添加至动态字符串对象;
遍历待分发消息,并分别将每次遍历获得的键值对信息和键值对分隔符为输入参数,调用动态字符串对象的字符串连接函数,将各键值对信息及各键值对分隔符添加至动态字符串对象;
以消息内容结束符和结构结束符为输入参数,调用动态字符串对象的字符串连接函数,将消息内容结束符和结构结束符添加至动态字符串对象;
调用动态字符串对象的字符串生成函数,生成目标字符串类型的目标字符串对象,作为目标分发消息。
进一步地,在上述装置的基础上,该装置还包括第一消息解析模块,配置于消息接收器,用于:
在消息分发器以目标分发消息为输入参数,调用消息接收对象中的通用消息分发函数,将目标分发消息分发至消息接收对象之后,分别调用目标字符串对象的字符串提取函数和字符串分割函数,获得目标字符串对象中的消息标识和各键值对信息,并依据消息标识和各键值对信息,触发执行消息标识对应的消息处理功能。
可选地,目标数据结构为Java对象简谱。
进一步地,目标分发消息生成模块420具体用于:
以待分发消息对应的初始消息对象为输入参数,调用Java对象简谱对应的抽象对象简谱类的第一类型转换函数,将初始消息对象转换为抽象对象简谱类的对象,生成初始简谱对象;
以预设消息标识字段和待分发消息中的消息标识为输入参数,调用初始简谱对象中的字段添加函数,将预设消息标识字段添加至初始简谱对象,并为预设消息标识字段设置字段值,生成第一过渡简谱对象;
调用第一过渡简谱对象中的字符串转换函数,将过渡简谱对象转换为字符串类型的Java对象简谱对象,作为目标分发消息。
进一步地,在上述装置的基础上,该装置还包括第二消息解析模块,配置于消息接收器,用于:
在消息分发器以目标分发消息为输入参数,调用消息接收对象中的通用消息分发函数,将目标分发消息分发至消息接收对象之后,以目标分发消息对应的Java对象简谱对象为输入参数,调用抽象对象简谱类的对象生成函数,将Java对象简谱对象转换为抽象对象简谱类型,生成第二过渡简谱对象;
以预设消息标识字段为输入参数,调用第二过渡简谱对象的字符串获取函数,获得目标分发消息中的消息标识;
以Java对象简谱对象和初始消息对象对应的类类型为输入参数,调用抽象对象简谱类的第二类型转换函数,由Java对象简谱对象生成类类型对应的解析消息对象;
依据消息标识和解析消息对象,触发执行消息标识对应的消息处理功能。
通过本发明实施例四的一种基于通用协议的消息分发装置,实现了不同功能对应的各种消息的直达式分发,提高了代码可维护性。
本发明实施例所提供的基于通用协议的消息分发装置可执行本发明任意实施例所提供的基于通用协议的消息分发方法,具备执行方法相应的功能模块和有益效果。
值得注意的是,上述基于通用协议的消息分发装置的实施例中,所包括的各个单元和模块只是按照功能逻辑进行划分的,但并不局限于上述的划分,只要能够实现相应的功能即可;另外,各功能单元的具体名称也只是为了便于相互区分,并不用于限制本发明的保护范围。
实施例五
参见图5,本实施例提供了一种设备500,其包括:一个或多个处理器520;存储装置510,用于存储一个或多个程序,当一个或多个程序被一个或多个处理器520执行,使得一个或多个处理器520实现本发明实施例所提供的基于通用协议的消息分发方法,包括:
消息分发对象获取待分发消息,并确定待分发消息对应的消息接收对象,其中,消息接收对象基于通用消息分发协议而生成,通用消息分发协议包含通用消息分发函数,通用消息分发函数的输入参数的数据类型为具有目标数据结构的目标字符串类型,目标数据结构中包含预设消息标识字段;
消息分发对象将待分发消息转换为目标字符串类型,生成目标分发消息;
消息分发对象以目标分发消息为输入参数,调用消息接收对象中的通用消息分发函数,将目标分发消息分发至消息接收对象。
当然,本领域技术人员可以理解,处理器520还可以实现本发明任意实施例所提供的基于通用协议的消息分发方法的技术方案。
图5显示的设备500仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。如图5所示,该设备500包括处理器520、存储装置510、输入装置530和输出装置540;设备中处理器520的数量可以是一个或多个,图5中以一个处理器520为例;设备中的处理器520、存储装置510、输入装置530和输出装置540可以通过总线或其他方式连接,图5中以通过总线550连接为例。
存储装置510作为一种计算机可读存储介质,可用于存储软件程序、计算机可执行程序以及模块,如本发明实施例中的基于通用协议的消息分发方法对应的程序指令/模块(例如,基于通用协议的消息分发装置中的待分发消息获取模块、目标分发消息生成模块和消息分发模块)。
存储装置510可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序;存储数据区可存储根据终端的使用所创建的数据等。此外,存储装置510可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他非易失性固态存储器件。在一些实例中,存储装置510可进一步包括相对于处理器520远程设置的存储器,这些远程存储器可以通过网络连接至设备。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
输入装置530可用于接收输入的数字或字符信息,以及产生与设备的用户设置以及功能控制有关的键信号输入。输出装置540可包括显示屏等显示设备。
实施例六
本实施例提供一种包含计算机可执行指令的存储介质,计算机可执行指令在由计算机处理器执行时用于执行一种基于通用协议的消息分发方法,该方法包括:
消息分发对象获取待分发消息,并确定待分发消息对应的消息接收对象,其中,消息接收对象基于通用消息分发协议而生成,通用消息分发协议包含通用消息分发函数,通用消息分发函数的输入参数的数据类型为具有目标数据结构的目标字符串类型,目标数据结构中包含预设消息标识字段;
消息分发对象将待分发消息转换为目标字符串类型,生成目标分发消息;
消息分发对象以目标分发消息为输入参数,调用消息接收对象中的通用消息分发函数,将目标分发消息分发至消息接收对象。
当然,本发明实施例所提供的一种包含计算机可执行指令的存储介质,其计算机可执行指令不限于如上的方法操作,还可以执行本发明任意实施例所提供的基于通用协议的消息分发方法中的相关操作。
通过以上关于实施方式的描述,所属领域的技术人员可以清楚地了解到,本发明可借助软件及必需的通用硬件来实现,当然也可以通过硬件实现,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品可以存储在计算机可读存储介质中,如计算机的软盘、只读存储器(Read-Only Memory,ROM)、随机存取存储器(RandomAccess Memory,RAM)、闪存(FLASH)、硬盘或光盘等,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所提供的基于通用协议的消息分发方法。
注意,上述仅为本发明的较佳实施例及所运用技术原理。本领域技术人员会理解,本发明不限于这里所述的特定实施例,对本领域技术人员来说能够进行各种明显的变化、重新调整和替代而不会脱离本发明的保护范围。因此,虽然通过以上实施例对本发明进行了较为详细的说明,但是本发明不仅仅限于以上实施例,在不脱离本发明构思的情况下,还可以包括更多其他等效实施例,而本发明的范围由所附的权利要求范围决定。
Claims (8)
1.一种基于通用协议的消息分发方法,其特征在于,包括:
消息分发对象获取待分发消息,并确定所述待分发消息对应的消息接收对象,其中,所述消息接收对象基于通用消息分发协议而生成,所述通用消息分发协议包含通用消息分发函数,所述通用消息分发函数的输入参数的数据类型为具有目标数据结构的目标字符串类型,所述目标数据结构中包含预设消息标识字段;
所述消息分发对象将所述待分发消息转换为所述目标字符串类型,生成目标分发消息;
所述消息分发对象以所述目标分发消息为输入参数,调用所述消息接收对象中的通用消息分发函数,将所述目标分发消息分发至所述消息接收对象;
所述目标数据结构包含结构开始符、消息标识键信息、与所述消息标识键信息对应的消息标识值信息、结构内容分割符、消息内容开始符、消息内容键值对信息及键值对分隔符、消息内容结束符和结构结束符,其中,所述结构开始符和所述结构结束符、以及所述消息内容开始符和所述消息内容结束符均为成对的字符,且所述结构开始符、所述消息内容开始符与所述目标数据结构中的剩余字符均不同;
所述待分发消息转换为所述目标字符串类型,生成目标分发消息包括:
所述消息分发对象调用动态字符串类生成动态字符串对象;
所述消息分发对象以所述结构开始符、所述待分发消息对应的消息标识字段、所述消息标识字段对应的消息标识、所述结构内容分割符和所述消息内容开始符为输入参数,调用所述动态字符串对象的字符串连接函数,将所述结构开始符、所述消息标识字段、所述消息标识和所述结构内容分割符添加至所述动态字符串对象;
所述消息分发对象遍历所述待分发消息,并分别将每次遍历获得的键值对信息和所述键值对分隔符为输入参数,调用所述动态字符串对象的所述字符串连接函数,将各所述键值对信息及各所述键值对分隔符添加至所述动态字符串对象;
所述消息分发对象以所述消息内容结束符和所述结构结束符为输入参数,调用所述动态字符串对象的所述字符串连接函数,将所述消息内容结束符和所述结构结束符添加至所述动态字符串对象;
所述消息分发对象调用所述动态字符串对象的字符串生成函数,生成所述目标字符串类型的目标字符串对象,作为所述目标分发消息。
2.根据权利要求1所述的方法,其特征在于,在所述消息分发对象以所述目标分发消息为输入参数,调用所述消息接收对象中的通用消息分发函数,将所述目标分发消息分发至所述消息接收对象之后,还包括:
所述消息接收对象分别调用所述目标字符串对象的字符串提取函数和字符串分割函数,获得所述目标字符串对象中的所述消息标识和各所述键值对信息,并依据所述消息标识和各所述键值对信息,触发执行所述消息标识对应的消息处理功能。
3.根据权利要求1所述的方法,其特征在于,所述目标数据结构为Java对象简谱。
4.根据权利要求3所述的方法,其特征在于,将所述待分发消息转换为所述目标字符串类型,生成目标分发消息包括:
所述消息分发对象以所述待分发消息对应的初始消息对象为输入参数,调用所述Java对象简谱对应的抽象对象简谱类的第一类型转换函数,将所述初始消息对象转换为所述抽象对象简谱类的对象,生成初始简谱对象;
所述消息分发对象以所述预设消息标识字段和所述待分发消息中的消息标识为输入参数,调用所述初始简谱对象中的字段添加函数,将所述预设消息标识字段添加至所述初始简谱对象,并为所述预设消息标识字段设置字段值,生成第一过渡简谱对象;
所述消息分发对象调用第一过渡简谱对象中的字符串转换函数,将所述过渡简谱对象转换为字符串类型的Java对象简谱对象,作为所述目标分发消息。
5.根据权利要求4所述的方法,其特征在于,在所述消息分发对象以所述目标分发消息为输入参数,调用所述消息接收对象中的通用消息分发函数,将所述目标分发消息分发至所述消息接收对象之后,还包括:
所述消息接收对象以所述目标分发消息对应的所述Java对象简谱对象为输入参数,调用所述抽象对象简谱类的对象生成函数,将所述Java对象简谱对象转换为抽象对象简谱类型,生成第二过渡简谱对象;
所述消息接收对象以所述预设消息标识字段为输入参数,调用所述第二过渡简谱对象的字符串获取函数,获得所述目标分发消息中的所述消息标识;
所述消息接收对象以所述Java对象简谱对象和所述初始消息对象对应的类类型为输入参数,调用所述抽象对象简谱类的第二类型转换函数,由所述Java对象简谱对象生成所述类类型对应的解析消息对象;
所述消息接收对象依据所述消息标识和所述解析消息对象,触发执行所述消息标识对应的消息处理功能。
6.一种基于通用协议的消息分发装置,其特征在于,包括:
待分发消息获取模块,配置于消息分发器,用于获取待分发消息,并确定所述待分发消息对应的消息接收对象,其中,所述消息接收对象基于通用消息分发协议而生成,所述通用消息分发协议包含通用消息分发函数,所述通用消息分发函数的输入参数的数据类型为具有目标数据结构的目标字符串类型,所述目标数据结构中包含预设消息标识字段;
目标分发消息生成模块,配置于消息分发器,用于将所述待分发消息转换为所述目标字符串类型,生成目标分发消息;
消息分发模块,配置于消息分发器,用于以所述目标分发消息为输入参数,调用所述消息接收对象中的通用消息分发函数,将所述目标分发消息分发至所述消息接收对象;
所述目标数据结构包含结构开始符、消息标识键信息、与消息标识键信息对应的消息标识值信息、结构内容分割符、消息内容开始符、消息内容键值对信息及键值对分隔符、消息内容结束符和结构结束符,其中,结构开始符和结构结束符、以及消息内容开始符和消息内容结束符均为成对的字符,且结构开始符、消息内容开始符与目标数据结构中的剩余字符均不同;
所述目标分发消息生成模块具体用于:
调用动态字符串类生成动态字符串对象;
以结构开始符、待分发消息对应的消息标识字段、消息标识字段对应的消息标识、结构内容分割符和消息内容开始符为输入参数,调用动态字符串对象的字符串连接函数,将结构开始符、消息标识字段、消息标识和结构内容分割符添加至动态字符串对象;
遍历待分发消息,并分别将每次遍历获得的键值对信息和键值对分隔符为输入参数,调用动态字符串对象的字符串连接函数,将各键值对信息及各键值对分隔符添加至动态字符串对象;
以消息内容结束符和结构结束符为输入参数,调用动态字符串对象的字符串连接函数,将消息内容结束符和结构结束符添加至动态字符串对象;
调用动态字符串对象的字符串生成函数,生成目标字符串类型的目标字符串对象,作为目标分发消息。
7.一种设备,其特征在于,所述设备包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-5中任一所述的基于通用协议的消息分发方法。
8.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1-5中任一所述的基于通用协议的消息分发方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910360967.3A CN110096379B (zh) | 2019-04-30 | 2019-04-30 | 基于通用协议的消息分发方法、装置、设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910360967.3A CN110096379B (zh) | 2019-04-30 | 2019-04-30 | 基于通用协议的消息分发方法、装置、设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110096379A CN110096379A (zh) | 2019-08-06 |
CN110096379B true CN110096379B (zh) | 2022-09-09 |
Family
ID=67446512
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910360967.3A Active CN110096379B (zh) | 2019-04-30 | 2019-04-30 | 基于通用协议的消息分发方法、装置、设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110096379B (zh) |
Families Citing this family (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112492353B (zh) * | 2019-09-12 | 2023-06-23 | 杭州山草互娱科技有限公司 | 直播间中数据的加工方法、装置、设备及存储介质 |
CN111144840A (zh) * | 2019-12-20 | 2020-05-12 | 北京明略软件系统有限公司 | 一种多部门文件分发方法及装置 |
CN113127103B (zh) * | 2019-12-30 | 2023-03-24 | 武汉斗鱼网络科技有限公司 | 一种信令系统及电子设备 |
CN111338822B (zh) * | 2020-02-25 | 2023-06-27 | 北京字节跳动网络技术有限公司 | 消息处理方法及装置 |
CN111866082A (zh) * | 2020-06-22 | 2020-10-30 | 远光软件股份有限公司 | 一种基于目标系统配置的数据分发方法和装置 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104993906A (zh) * | 2015-05-18 | 2015-10-21 | 中国船舶重工集团公司第七二二研究所 | 一种消息传输的方法及系统 |
CN105900061A (zh) * | 2014-10-22 | 2016-08-24 | 华为技术有限公司 | 对象存储系统中的业务流控制方法、控制器和系统 |
CN108469993A (zh) * | 2018-04-04 | 2018-08-31 | 武汉斗鱼网络科技有限公司 | 消息转发方法、计算机可读存储介质及电子设备 |
CN108933968A (zh) * | 2018-07-03 | 2018-12-04 | 武汉斗鱼网络科技有限公司 | 一种消息格式的转换方法、装置、存储介质及安卓终端 |
CN109005465A (zh) * | 2018-08-07 | 2018-12-14 | 武汉斗鱼网络科技有限公司 | 弹幕消息分发方法、装置、设备及存储介质 |
Family Cites Families (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8806506B2 (en) * | 2008-09-30 | 2014-08-12 | Ebay Inc. | System and method for processing messages using a common interface platform supporting multiple pluggable data formats in a service-oriented pipeline architecture |
US9632824B2 (en) * | 2014-05-30 | 2017-04-25 | Genesys Telecommunications Laboratories, Inc. | System and method for application inactivity control |
-
2019
- 2019-04-30 CN CN201910360967.3A patent/CN110096379B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105900061A (zh) * | 2014-10-22 | 2016-08-24 | 华为技术有限公司 | 对象存储系统中的业务流控制方法、控制器和系统 |
CN104993906A (zh) * | 2015-05-18 | 2015-10-21 | 中国船舶重工集团公司第七二二研究所 | 一种消息传输的方法及系统 |
CN108469993A (zh) * | 2018-04-04 | 2018-08-31 | 武汉斗鱼网络科技有限公司 | 消息转发方法、计算机可读存储介质及电子设备 |
CN108933968A (zh) * | 2018-07-03 | 2018-12-04 | 武汉斗鱼网络科技有限公司 | 一种消息格式的转换方法、装置、存储介质及安卓终端 |
CN109005465A (zh) * | 2018-08-07 | 2018-12-14 | 武汉斗鱼网络科技有限公司 | 弹幕消息分发方法、装置、设备及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN110096379A (zh) | 2019-08-06 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110096379B (zh) | 基于通用协议的消息分发方法、装置、设备及存储介质 | |
CN108306877B (zh) | 基于node js的用户身份信息的验证方法、装置和存储介质 | |
US9824080B2 (en) | Automatic generation of forms for device configuration | |
CN110474794B (zh) | 一种sdn架构的信息转换方法和系统 | |
CN114760369B (zh) | 一种协议元数据提取方法、装置、设备及存储介质 | |
CN110210212A (zh) | 一种数据处理方法、装置以及相关设备 | |
CN109343983B (zh) | 功能模块间的信息交互方法、装置、设备及存储介质 | |
CN112995269B (zh) | 数据处理方法、计算机设备以及可读存储介质 | |
CN112732572A (zh) | 服务的测试方法、装置及系统、存储介质、电子装置 | |
CN111858113B (zh) | 应用程序的修复方法、装置、业务系统及存储介质 | |
CN111555915A (zh) | 一种基于插件配置的动态网元控制系统 | |
CN113867732A (zh) | 一种报文信息处理方法、系统以及存储介质 | |
CN113806037A (zh) | 服务的调用方法、装置、存储介质及电子设备 | |
CN108595331B (zh) | 异步接口的测试方法、介质、装置和计算设备 | |
CN114090388A (zh) | 信息获取方法、服务器集群、服务器及设备 | |
CN112929419A (zh) | 一种数据包传输方法、装置、电子设备及可读存储介质 | |
CN109388388B (zh) | 功能模块间的信息交互方法、装置、设备及存储介质 | |
CN110933188A (zh) | 远程服务的调用方法、系统、服务器及存储介质 | |
CN111427710B (zh) | 应用程序中组件的通信方法、装置、设备及存储介质 | |
CN109144520B (zh) | Android中不同对象间的信息交互方法、装置、设备和存储介质 | |
CN109144750B (zh) | 一种消息处理方法、装置、电子设备及存储介质 | |
CN110955604A (zh) | 一种信息显示方法、装置、服务器及存储介质 | |
US20180124576A1 (en) | Method and apparatus for implementing member resource processing | |
CN112738202B (zh) | 一种数据处理方法和相关装置以及存储介质 | |
CN112818183A (zh) | 一种数据合成方法、装置、计算机设备和存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |