CN112688863B - 网关数据处理方法、装置及电子设备 - Google Patents

网关数据处理方法、装置及电子设备 Download PDF

Info

Publication number
CN112688863B
CN112688863B CN201910996003.8A CN201910996003A CN112688863B CN 112688863 B CN112688863 B CN 112688863B CN 201910996003 A CN201910996003 A CN 201910996003A CN 112688863 B CN112688863 B CN 112688863B
Authority
CN
China
Prior art keywords
serialization
layer
factory
data
management
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
Application number
CN201910996003.8A
Other languages
English (en)
Other versions
CN112688863A (zh
Inventor
任铮
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing ByteDance Network Technology Co Ltd
Original Assignee
Beijing ByteDance Network Technology Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Beijing ByteDance Network Technology Co Ltd filed Critical Beijing ByteDance Network Technology Co Ltd
Priority to CN201910996003.8A priority Critical patent/CN112688863B/zh
Publication of CN112688863A publication Critical patent/CN112688863A/zh
Application granted granted Critical
Publication of CN112688863B publication Critical patent/CN112688863B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Information Transfer Between Computers (AREA)
  • Computer And Data Communications (AREA)

Abstract

本公开实施例中提供了一种网关数据处理方法、装置及电子设备,属于数据处理技术领域,该方法包括:在方法调用层的SDK中定义多个注解;利用与所述控制信息对应的内容类型,在序列化管理中基于序列化工厂创建序列化对象;在接收到的传输层针对所述请求对象返回的包含头数据的响应数据之后,基于所述头数据中包含的内容类型,从序列化管理中找到注册的序列化工厂来创建反序列化对象。本公开的方案能够提高网关数据处理的效率。

Description

网关数据处理方法、装置及电子设备
技术领域
本公开涉及数据处理技术领域,尤其涉及一种网关数据处理方法、装置及电子设备。
背景技术
使用网络请求获取服务端数据是客户端开发上一个核心工作。传统的开发流程需要先定义接口,创建实体类和接口实现然后在使用时传入参数拼接请求,解析返回的结果。整个流程都需开发者介入,导致开发的效率较低。
发明内容
有鉴于此,本公开实施例提供一种网关数据处理方法、装置及电子设备,至少部分解决现有技术中存在的问题。
第一方面,本公开实施例提供了一种网关数据处理方法,包括:
在方法调用层的SDK中定义多个注解,以便于服务调用生成的方法通过动态代理来解析所述注解获取请求控制信息和参数,并所述控制信息和所述参数传给序列化层处理;
利用与所述控制信息对应的内容类型,在序列化管理中基于序列化工厂创建序列化对象,以便于对所述参数进行序列化操作,所述序列化操作的结果转换为发送至传输层的请求对象;
在接收到的传输层针对所述请求对象返回的包含头数据的响应数据之后,基于所述头数据中包含的内容类型,从序列化管理中找到注册的序列化工厂来创建反序列化对象,以便于对所述响应数据中的响应流执行生成返回实体的反序列化操作。
根据本公开实施例的一种具体实现方式,所述在方法调用层的SDK中定义多个注解,包括:
定义支持生成实体注解RpcFieldTag,用于标记需要支持的protobuf或thrift的原始定义信息,以便收到传输层的二进制数据时能动态解析出来。
根据本公开实施例的一种具体实现方式,所述在方法调用层的SDK中定义多个注解,包括:
定义支持服务调用方法的注解RpcSerializer和注解RpcOperation,分别用于标记序列化方式、以及控制请求方式和资源地址。
根据本公开实施例的一种具体实现方式,所述在序列化管理中基于序列化工厂创建序列化对象,以便于对所述参数进行序列化操作,包括:
根据所述内容类型在序列化管理中找到注册的序列化工厂;
基于所述序列化工厂,创建序列化对象;
基于所述序列化对象,对所述参数进行序列化操作。。
根据本公开实施例的一种具体实现方式,所述在序列化管理中基于序列化工厂创建序列化对象之前,所述方法还包括:
在序列化层与反序列化层内置多种序列化工厂;
设置同一实体支持所述多种序列化工厂对应的多种序列化协议。
根据本公开实施例的一种具体实现方式,所述设置同一实体支持所述多种序列化工厂对应的多种序列化协议,包括:
在生成代码时设置是否支持精简模型解码的选项;
当存在支持精简模型解码的选项时,在生成的精简java实体类的每个字段上使用RpcFiledTag标记原始的protobuf或thrift字段定义标签信息。
根据本公开实施例的一种具体实现方式,所述在序列化管理中基于序列化工厂创建序列化对象之前,所述方法还包括:
在传输层设置网络传输适配接口,所述适配接口可扩展第三方式网络库来实现网络层的数据传输;
基于所述适配接口来接收请求控制信息和序列化后的二进制数据,实现同步和异步请求,并返回网络响应数据。
根据本公开实施例的一种具体实现方式,所述在序列化管理中基于序列化工厂创建序列化对象之前,所述方法还包括:
在调用层设置方法拦截器,用于对方法调用前,后,异常拦截;
在传输层设置传输拦截器,用于对传输层的请求和返回数据进行拦截修改。
第二方面,本公开实施例提供了一种网关数据处理装置,包括:
定义模块,用于在方法调用层的SDK中定义多个注解,以便于服务调用生成的方法通过动态代理来解析所述注解获取请求控制信息和参数,并所述控制信息和所述参数传给序列化层处理;
创建模块,用于利用与所述控制信息对应的内容类型,在序列化管理中基于序列化工厂创建序列化对象,以便于对所述参数进行序列化操作,所述序列化操作的结果转换为发送至传输层的请求对象;
执行模块,用于在接收到的传输层针对所述请求对象返回的包含头数据的响应数据之后,基于所述头数据中包含的内容类型,从序列化管理中找到注册的序列化工厂来创建反序列化对象,以便于对所述响应数据中的响应流执行生成返回实体的反序列化操作。
第三方面,本公开实施例还提供了一种电子设备,该电子设备包括:
至少一个处理器;以及,
与该至少一个处理器通信连接的存储器;其中,
该存储器存储有可被该至少一个处理器执行的指令,该指令被该至少一个处理器执行,以使该至少一个处理器能够执行前述任第一方面或第一方面的任一实现方式中的网关数据处理方法。
第四方面,本公开实施例还提供了一种非暂态计算机可读存储介质,该非暂态计算机可读存储介质存储计算机指令,该计算机指令用于使该计算机执行前述第一方面或第一方面的任一实现方式中的网关数据处理方法。
第五方面,本公开实施例还提供了一种计算机程序产品,该计算机程序产品包括存储在非暂态计算机可读存储介质上的计算程序,该计算机程序包括程序指令,当该程序指令被计算机执行时,使该计算机执行前述第一方面或第一方面的任一实现方式中的网关数据处理方法。
本公开实施例中的网关数据处理方案,包括在方法调用层的SDK中定义多个注解,以便于服务调用生成的方法通过动态代理来解析所述注解获取请求控制信息和参数,并所述控制信息和所述参数传给序列化层处理;利用与所述控制信息对应的内容类型,在序列化管理中基于序列化工厂创建序列化对象,以便于对所述参数进行序列化操作,所述序列化操作的结果转换为发送至传输层的请求对象;在接收到的传输层针对所述请求对象返回的包含头数据的响应数据之后,基于所述头数据中包含的内容类型,从序列化管理中找到注册的序列化工厂来创建反序列化对象,以便于对所述响应数据中的响应流执行生成返回实体的反序列化操作。通过本公开的方案,用户无需关心网络细节和序列化,基于sdk直接调用生成代码服务即可获取服务端数据,提高了数据处理的效率。
附图说明
为了更清楚地说明本公开实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本公开的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其它的附图。
图1为本公开实施例提供的一种网关数据处理流程示意图;
图2为本公开实施例提供的另一种网关数据处理流程示意图;
图3为本公开实施例提供的另一种网关数据处理流程示意图;
图4为本公开实施例提供的另一种网关数据处理流程示意图;
图5为本公开实施例提供的一种网关数据处理装置结构示意图;
图6为本公开实施例提供的电子设备示意图。
具体实施方式
下面结合附图对本公开实施例进行详细描述。
以下通过特定的具体实例说明本公开的实施方式,本领域技术人员可由本说明书所揭露的内容轻易地了解本公开的其他优点与功效。显然,所描述的实施例仅仅是本公开一部分实施例,而不是全部的实施例。本公开还可以通过另外不同的具体实施方式加以实施或应用,本说明书中的各项细节也可以基于不同观点与应用,在没有背离本公开的精神下进行各种修饰或改变。需说明的是,在不冲突的情况下,以下实施例及实施例中的特征可以相互组合。基于本公开中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本公开保护的范围。
需要说明的是,下文描述在所附权利要求书的范围内的实施例的各种方面。应显而易见,本文中所描述的方面可体现于广泛多种形式中,且本文中所描述的任何特定结构及/或功能仅为说明性的。基于本公开,所属领域的技术人员应了解,本文中所描述的一个方面可与任何其它方面独立地实施,且可以各种方式组合这些方面中的两者或两者以上。举例来说,可使用本文中所阐述的任何数目个方面来实施设备及/或实践方法。另外,可使用除了本文中所阐述的方面中的一或多者之外的其它结构及/或功能性实施此设备及/或实践此方法。
还需要说明的是,以下实施例中所提供的图示仅以示意方式说明本公开的基本构想,图式中仅显示与本公开中有关的组件而非按照实际实施时的组件数目、形状及尺寸绘制,其实际实施时各组件的型态、数量及比例可为一种随意的改变,且其组件布局型态也可能更为复杂。
另外,在以下描述中,提供具体细节是为了便于透彻理解实例。然而,所属领域的技术人员将理解,可在没有这些特定细节的情况下实践所述方面。
本公开实施例提供一种网关数据处理方法。本实施例提供的网关数据处理方法可以由一计算装置来执行,该计算装置可以实现为软件,或者实现为软件和硬件的组合,该计算装置可以集成设置在服务器、终端设备等中。
参见图1及图2,本公开实施例提供的一种网关数据处理方法,包括如下步骤:
S101,在方法调用层的SDK中定义多个注解,以便于服务调用生成的方法通过动态代理来解析所述注解获取请求控制信息和参数,并所述控制信息和所述参数传给序列化层处理。
方法调用层用于不是执行具体的调用方法。而是确定该调用哪一个方法来完成调用。这样一来,能够保障方法调用的动态性和灵活性。
具体的,可以在SDK上定义多个注解,这些注解被用在生成的代码和生成的服务调用上。调用生成的方法会通过动态代理来解析注解获取请求控制信息,再将参数和控制信息传给序列化层处理。
作为一种情况,可以设置支持生成实体上的注解RpcFieldTag,其作用是标记需要支持的protobuf或thrift的原始定义信息(field number和label),有了这些标记就可运行时动态解析protobuf或thrift的二进制数据。
作为另外一种情况,还可以设置支持服务调用方法上的注解RpcSerializer和RpcOperation,前者用于标记序列化方式,后者用于控制请求方式和资源地址。
当然,也可以根据实际的情况设置其他的注解。
S102,利用与所述控制信息对应的内容类型,在序列化管理中基于序列化工厂创建序列化对象,以便于对所述参数进行序列化操作,所述序列化操作的结果转换为发送至传输层的请求对象。
除了设置方法调用层之外,还可以设置序列化反序列化层,通过设置序列化反序列化层,能够对方法调用层发送的内容类型(content-type)和参数进行解析,生成面向传输层的传送请求,同时对传输层(网络传输层)返回的传输响应进行解析,生成相应的实体。
序列化(Serialization)是将对象的状态信息转换为可以存储或传输的形式的过程。在序列化期间,对象将其当前状态写入到临时或持久性存储区。以后,可以通过从存储区中读取或反序列化对象的状态,重新创建该对象。作为一种方式,对于可能包含重要的安全性数据的对象,优先选择使该对象不可序列化。如果它必须为可序列化的,则通过生成特定字段来保存不可序列化的重要数据。
具体的,在接收到方法调用层传输的内容类型和参数之后,利用序列化层服务方法调用的实体对象作为入参,调用方法上会有序列化方式的注解得到内容类型。根据该内容类型在序列化管理中找到注册到的序列化工厂,用来创建序列化对象,之后再对参数进行序列化操作。最后将序列化操作的结果转换为一个传输层的请求对象交给传输层处理网络请求。
S103,在接收到的传输层针对所述请求对象返回的包含头数据的响应数据之后,基于所述头数据中包含的内容类型,从序列化管理中找到注册的序列化工厂来创建反序列化对象,以便于对所述响应数据中的响应流执行生成返回实体的反序列化操作。
响应于序列化层发送的传输请求(TransportRequest),传输层会返回传输响应(TransportResponse),传输层返回的传输响应数据包含原始的响应数据流和头(header)数据。头数据中包含有相应的内容类型,通过该内容类型,可以从序列化管理中找到注册的序列化工厂创建反序列化对象,再对响应流做反序列化成对象的操作,以便于生成面向方法调用层的实体。方法调用层的返回实体可以通过API调用服务来进行相应的调用。
通过上述方式,能够使移动网关在接入后导入代码即可调用。不用手写网络相关的接口,实体和序列化实现了。且支持动态选择序列化,很多业务会选择protobuf序列化(数据小,编码效率更高),这样开发调试可使用json便于获取数据,上线后即可转为protobuf。
根据本公开实施例的一种具体实现方式,所述在方法调用层的SDK中定义多个注解,包括:定义支持生成实体注解RpcFieldTag,用于标记需要支持的protobuf或thrift的原始定义信息,以便收到传输层的二进制数据时能动态解析出来。通过该方式,能够使方法调用层支持多种方法调用。
根据本公开实施例的一种具体实现方式,所述在方法调用层的SDK中定义多个注解,包括:定义支持服务调用方法的注解RpcSerializer和注解RpcOperation,分别用于标记序列化方式、以及控制请求方式和资源地址。通过该方式,能够使方法调用层支持多种方法调用。
参见图3,根据本公开实施例的一种具体实现方式,所述在序列化管理中基于序列化工厂创建序列化对象,以便于对所述参数进行序列化操作,包括:
S301,根据所述内容类型在序列化管理中找到注册的序列化工厂;
S302,基于所述序列化工厂,创建序列化对象;
S303,基于所述序列化对象,对所述参数进行序列化操作。通过该方式,能够通过序列化工厂的方式执行序列化操作。
根据本公开实施例的一种具体实现方式,所述在序列化管理中基于序列化工厂创建序列化对象之前,所述方法还包括:在序列化层与反序列化层内置多种序列化工厂;设置同一实体支持所述多种序列化工厂对应的多种序列化协议。通过该方式,能够基于多种不同类型的额序列化协议来进行序列化操作。
根据本公开实施例的一种具体实现方式,所述设置同一实体支持所述多种序列化工厂对应的多种序列化协议,包括:在生成代码时设置是否支持精简模型解码的选项;当存在支持精简模型解码的选项时,在生成的精简java实体类的每个字段上使用RpcFiledTag标记原始的protobuf或thrift字段定义标签信息。
具体的,可以内置json,protobuf,thrift三种序列化工厂实现,它们有不同的编码和解码协议。为了让同一实体支持这三种序列化协议,但又不生成冗余代码。在生成代码时有选项是否支持精简模型解码protobuf或thrift,如果是就会在生成的精简java实体类的每个字段上使用RpcFiledTag标记原始的protobuf或thrift字段定义时的tag信息。当protobuf和thrift同时支持时,要求定义原始数据结构的proto和thrift idl对字段的描述要一致。
通过RpcFieldTag标记的实体就可同时支持json,protobuf,thrift的不同协议序列化和反序列化了。序列化管理会根据请求或返回的头字字段中获取内容类型,根据它获取注册好的序列化工厂。请求时用它创建序列化对象对参数encode操作;解析返回数据时用它创建反序列化对象对响应流做编码操作。如图2所示。内容类型为application/json时就选择JsonSerializeFactory,为application/x-protobuf时就选PbSerializeFactory。
精简实体类没有原生protobuf或thrift官方生成的冗余解析代码,所以实现上是运行时读取注解来获取原始定义的filed number和label再结合字段类型来做编码和解码过程。protobuf和thrift编码过程非常相似。按官方协议格式,每种基本数据类型都有固定的编码和解码操作的Adapter,复杂对象是由多个个基本数据作为成员组成,且编解码是递归操作。通过该方式,能够方便的对标签信息进行定义。
参见图4,根据本公开实施例的一种具体实现方式,所述在序列化管理中基于序列化工厂创建序列化对象之前,所述方法还包括:
S401,在传输层设置网络传输适配接口,所述适配接口可扩展第三方式网络库来实现网络层的数据传输;
S402,基于所述适配接口来接收请求控制信息和序列化后的二进制数据,实现同步和异步请求,并返回网络响应数据。
通过该方式,能够方便在传输层基于适配接口来进行数据的传输和响应。
根据本公开实施例的一种具体实现方式,所述在序列化管理中基于序列化工厂创建序列化对象之前,所述方法还包括:在调用层设置方法拦截器,用于对方法调用前,后,异常拦截;在传输层设置传输拦截器,用于对传输层的请求和返回数据进行拦截修改。通过该方式,能够有效的对传输数据进行拦截修改。
与上面的方法实施例相对应,参见图5,本公开实施例还提供了一种网关数据处理装置50,包括:
定义模块501,用于在方法调用层的SDK中定义多个注解,以便于服务调用生成的方法通过动态代理来解析所述注解获取请求控制信息和参数,并所述控制信息和所述参数传给序列化层处理。
方法调用层用于不是执行具体的调用方法。而是确定该调用哪一个方法来完成调用。这样一来,能够保障方法调用的动态性和灵活性。
具体的,可以在SDK上定义多个注解,这些注解被用在生成的代码和生成的服务调用上。调用生成的方法会通过动态代理来解析注解获取请求控制信息,再将参数和控制信息传给序列化层处理。
作为一种情况,可以设置支持生成实体上的注解RpcFieldTag,其作用是标记需要支持的protobuf或thrift的原始定义信息(field number和label),有了这些标记就可运行时动态解析protobuf或thrift的二进制数据。
作为另外一种情况,还可以设置支持服务调用方法上的注解RpcSerializer和RpcOperation,前者用于标记序列化方式,后者用于控制请求方式和资源地址。
当然,也可以根据实际的情况设置其他的注解。
创建模块502,用于利用与所述控制信息对应的内容类型,在序列化管理中基于序列化工厂创建序列化对象,以便于对所述参数进行序列化操作,所述序列化操作的结果转换为发送至传输层的请求对象。
除了设置方法调用层之外,还可以设置序列化反序列化层,通过设置序列化反序列化层,能够对方法调用层发送的内容类型和参数进行解析,生成面向传输层的传送请求,同时对传输层(网络传输层)返回的传输响应进行解析,生成相应的实体。
序列化(Serialization)是将对象的状态信息转换为可以存储或传输的形式的过程。在序列化期间,对象将其当前状态写入到临时或持久性存储区。以后,可以通过从存储区中读取或反序列化对象的状态,重新创建该对象。作为一种方式,对于可能包含重要的安全性数据的对象,优先选择使该对象不可序列化。如果它必须为可序列化的,则通过生成特定字段来保存不可序列化的重要数据。
具体的,在接收到方法调用层传输的内容类型和参数之后,利用序列化层服务方法调用的实体对象作为入参,调用方法上会有序列化方式的注解得到内容类型。根据该内容类型在序列化管理中找到注册到的序列化工厂,用来创建序列化对象,之后再对参数进行序列化操作。最后将序列化操作的结果转换为一个传输层的请求对象交给传输层处理网络请求。
执行模块503,用于在接收到的传输层针对所述请求对象返回的包含头数据的响应数据之后,基于所述头数据中包含的内容类型,从序列化管理中找到注册的序列化工厂来创建反序列化对象,以便于对所述响应数据中的响应流执行生成返回实体的反序列化操作。
响应于序列化层发送的传输请求,传输层会返回传输响应,传输层返回的传输响应数据包含原始的响应数据流和头数据。头数据中包含有相应的内容类型,通过该内容类型,可以从序列化管理中找到注册的序列化工厂创建反序列化对象,再对响应流做反序列化成对象的操作,以便于生成面向方法调用层的实体。方法调用层的返回实体可以通过API调用服务来进行相应的调用。
通过上述方式,能够使移动网关在接入后导入代码即可调用。不用手写网络相关的接口,实体和序列化实现了。且支持动态选择序列化,很多业务会选择protobuf序列化(数据小,编码效率更高),这样开发调试可使用json便于获取数据,上线后即可转为protobuf。
图5所示装置可以对应的执行上述方法实施例中的内容,本实施例未详细描述的部分,参照上述方法实施例中记载的内容,在此不再赘述。
参见图6,本公开实施例还提供了一种电子设备60,该电子设备包括:
至少一个处理器;以及,
与该至少一个处理器通信连接的存储器;其中,
该存储器存储有可被该至少一个处理器执行的指令,该指令被该至少一个处理器执行,以使该至少一个处理器能够执行前述方法实施例中网关数据处理方法。
本公开实施例还提供了一种非暂态计算机可读存储介质,该非暂态计算机可读存储介质存储计算机指令,该计算机指令用于使该计算机执行前述方法实施例中。
本公开实施例还提供了一种计算机程序产品,该计算机程序产品包括存储在非暂态计算机可读存储介质上的计算程序,该计算机程序包括程序指令,当该程序指令被计算机执行时,使该计算机执行前述方法实施例中的网关数据处理方法。
下面参考图6,其示出了适于用来实现本公开实施例的电子设备60的结构示意图。本公开实施例中的电子设备可以包括但不限于诸如移动电话、笔记本电脑、数字广播接收器、PDA(个人数字助理)、PAD(平板电脑)、PMP(便携式多媒体播放器)、车载终端(例如车载导航终端)等等的移动终端以及诸如数字TV、台式计算机等等的固定终端。图6示出的电子设备仅仅是一个示例,不应对本公开实施例的功能和使用范围带来任何限制。
如图6所示,电子设备60可以包括处理装置(例如中央处理器、图形处理器等)601,其可以根据存储在只读存储器(ROM)602中的程序或者从存储装置608加载到随机访问存储器(RAM)603中的程序而执行各种适当的动作和处理。在RAM 603中,还存储有电子设备60操作所需的各种程序和数据。处理装置601、ROM 602以及RAM 603通过总线604彼此相连。输入/输出(I/O)接口605也连接至总线604。
通常,以下装置可以连接至I/O接口605:包括例如触摸屏、触摸板、键盘、鼠标、图像传感器、麦克风、加速度计、陀螺仪等的输入装置606;包括例如液晶显示器(LCD)、扬声器、振动器等的输出装置607;包括例如磁带、硬盘等的存储装置608;以及通信装置609。通信装置609可以允许电子设备60与其他设备进行无线或有线通信以交换数据。虽然图中示出了具有各种装置的电子设备60,但是应理解的是,并不要求实施或具备所有示出的装置。可以替代地实施或具备更多或更少的装置。
特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信装置609从网络上被下载和安装,或者从存储装置608被安装,或者从ROM 602被安装。在该计算机程序被处理装置601执行时,执行本公开实施例的方法中限定的上述功能。
需要说明的是,本公开上述的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本公开中,计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读信号介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:电线、光缆、RF(射频)等等,或者上述的任意合适的组合。
上述计算机可读介质可以是上述电子设备中所包含的;也可以是单独存在,而未装配入该电子设备中。
上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该电子设备执行时,使得该电子设备:获取至少两个网际协议地址;向节点评价设备发送包括所述至少两个网际协议地址的节点评价请求,其中,所述节点评价设备从所述至少两个网际协议地址中,选取网际协议地址并返回;接收所述节点评价设备返回的网际协议地址;其中,所获取的网际协议地址指示内容分发网络中的边缘节点。
或者,上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该电子设备执行时,使得该电子设备:接收包括至少两个网际协议地址的节点评价请求;从所述至少两个网际协议地址中,选取网际协议地址;返回选取出的网际协议地址;其中,接收到的网际协议地址指示内容分发网络中的边缘节点。
可以以一种或多种程序设计语言或其组合来编写用于执行本公开的操作的计算机程序代码,上述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
附图中的流程图和框图,图示了按照本公开各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本公开实施例中所涉及到的单元可以通过软件的方式实现,也可以通过硬件的方式来实现。其中,单元的名称在某种情况下并不构成对该单元本身的限定,例如,第一获取单元还可以被描述为“获取至少两个网际协议地址的单元”。
应当理解,本公开的各部分可以用硬件、软件、固件或它们的组合来实现。
以上所述,仅为本公开的具体实施方式,但本公开的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本公开揭露的技术范围内,可轻易想到的变化或替换,都应涵盖在本公开的保护范围之内。因此,本公开的保护范围应以权利要求的保护范围为准。

Claims (11)

1.一种网关数据处理方法,其特征在于,包括:
在方法调用层的SDK中定义多个注解,以便于服务调用生成的方法通过动态代理来解析所述注解获取请求控制信息和参数,并将所述控制信息和所述参数传给序列化层处理;
利用与所述控制信息对应的内容类型,在序列化管理中基于序列化工厂创建序列化对象,以便于对所述参数进行序列化操作,所述序列化操作的结果转换为发送至传输层的请求对象;
在接收到传输层针对所述请求对象返回的包含头数据的响应数据之后,基于所述头数据中包含的内容类型,从序列化管理中找到注册的序列化工厂来创建反序列化对象,以便于对所述响应数据中的响应流执行生成返回实体的反序列化操作。
2.根据权利要求1所述的方法,其特征在于,所述在方法调用层的SDK中定义多个注解,包括:
定义支持生成实体的注解RpcFieldTag,用于标记需要支持的protobuf或thrift的原始定义信息,以便收到传输层的二进制数据时能动态解析出来。
3.根据权利要求1所述的方法,其特征在于,所述在方法调用层的SDK中定义多个注解,包括:
定义支持服务调用方法的注解RpcSerializer和注解RpcOperation,分别用于标记序列化方式、以及控制请求方式和资源地址。
4.根据权利要求1所述的方法,其特征在于,所述在序列化管理中基于序列化工厂创建序列化对象,以便于对所述参数进行序列化操作,包括:
根据所述内容类型在序列化管理中找到注册的序列化工厂;
基于所述序列化工厂,创建序列化对象;
基于所述序列化对象,对所述参数进行序列化操作。
5.根据权利要求1所述的方法,其特征在于,所述在序列化管理中基于序列化工厂创建序列化对象之前,所述方法还包括:
在序列化层与反序列化层内置多种序列化工厂;
设置同一实体支持所述多种序列化工厂对应的多种序列化协议。
6.根据权利要求5所述的方法,其特征在于,所述设置同一实体支持所述多种序列化工厂对应的多种序列化协议,包括:
在生成代码时设置是否支持精简模型解码的选项;
当存在支持精简模型解码的选项时,在生成的精简java实体类的每个字段上使用RpcFiledTag标记原始的protobuf或thrift字段定义标签信息。
7.根据权利要求1-6中任一项所述的方法,其特征在于,所述在序列化管理中基于序列化工厂创建序列化对象之前,所述方法还包括:
在传输层设置网络传输适配接口,所述适配接口可扩展第三方式网络库来实现网络层的数据传输;
基于所述适配接口来接收请求控制信息和序列化后的二进制数据,实现同步和异步请求,并返回网络响应数据。
8.根据权利要求1-6中任一项所述的方法,其特征在于,所述在序列化管理中基于序列化工厂创建序列化对象之前,所述方法还包括:
在调用层设置方法拦截器,用于对方法调用前、后,异常拦截;
在传输层设置传输拦截器,用于对传输层的请求和返回数据进行拦截修改。
9.一种网关数据处理装置,其特征在于,包括:
定义模块,用于在方法调用层的SDK中定义多个注解,以便于服务调用生成的方法通过动态代理来解析所述注解获取请求控制信息和参数,并所述控制信息和所述参数传给序列化层处理;
创建模块,用于利用与所述控制信息对应的内容类型,在序列化管理中基于序列化工厂创建序列化对象,以便于对所述参数进行序列化操作,所述序列化操作的结果转换为发送至传输层的请求对象;
执行模块,用于在接收到的传输层针对所述请求对象返回的包含头数据的响应数据之后,基于所述头数据中包含的内容类型,从序列化管理中找到注册的序列化工厂来创建反序列化对象,以便于对所述响应数据中的响应流执行生成返回实体的反序列化操作。
10.一种电子设备,其特征在于,所述电子设备包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行前述任一权利要求1-8所述的网关数据处理方法。
11.一种非暂态计算机可读存储介质,该非暂态计算机可读存储介质存储计算机指令,该计算机指令用于使该计算机执行前述任一权利要求1-8所述的网关数据处理方法。
CN201910996003.8A 2019-10-18 2019-10-18 网关数据处理方法、装置及电子设备 Active CN112688863B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201910996003.8A CN112688863B (zh) 2019-10-18 2019-10-18 网关数据处理方法、装置及电子设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201910996003.8A CN112688863B (zh) 2019-10-18 2019-10-18 网关数据处理方法、装置及电子设备

Publications (2)

Publication Number Publication Date
CN112688863A CN112688863A (zh) 2021-04-20
CN112688863B true CN112688863B (zh) 2023-01-10

Family

ID=75445236

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201910996003.8A Active CN112688863B (zh) 2019-10-18 2019-10-18 网关数据处理方法、装置及电子设备

Country Status (1)

Country Link
CN (1) CN112688863B (zh)

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106888129A (zh) * 2017-04-20 2017-06-23 国家电网公司 一种可弹性伸缩的分布式服务管理系统及其方法

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
SG186910A1 (en) * 2010-07-09 2013-02-28 Visa Int Service Ass Gateway abstraction layer
US20180203744A1 (en) * 2017-01-09 2018-07-19 Alexander WIESMAIER Data ingestion and analytics platform with systems, methods and computer program products useful in conjunction therewith

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106888129A (zh) * 2017-04-20 2017-06-23 国家电网公司 一种可弹性伸缩的分布式服务管理系统及其方法

Also Published As

Publication number Publication date
CN112688863A (zh) 2021-04-20

Similar Documents

Publication Publication Date Title
CN110489101B (zh) 接口模拟方法、系统、介质和电子设备
CN111338623B (zh) 一种开发用户界面的方法、装置、介质和电子设备
CN112684968A (zh) 页面展示方法、装置、电子设备和计算机可读介质
CN111309304B (zh) 一种生成idl文件的方法、装置、介质和电子设备
CN113821352A (zh) 一种远程服务的调用方法和装置
CN110377273B (zh) 一种数据处理的方法、装置、介质和电子设备
CN112631590A (zh) 组件库生成方法、装置、电子设备和计算机可读介质
CN111324376A (zh) 功能配置方法、装置、电子设备及计算机可读介质
CN113391860B (zh) 服务请求处理方法、装置、电子设备及计算机存储介质
CN111752644A (zh) 接口模拟方法、装置、设备及存储介质
CN110618811B (zh) 信息呈现方法和装置
CN111309406A (zh) 应用程序的事件处理方法、装置及电子设备
CN112688863B (zh) 网关数据处理方法、装置及电子设备
CN109669720B (zh) 基于Promise的链式异步请求处理方法、装置及电子设备
CN113835790B (zh) 基于Android的分页页面显示方法和装置
CN114637531A (zh) 应用程序接口动态生成方法及装置
CN110086880B (zh) 创建网络请求的实例的方法和装置
CN111813407B (zh) 游戏开发方法、游戏运行方法、装置和电子设备
CN113778566A (zh) 原生应用调用方法、装置、电子设备和计算机可读介质
CN110908711A (zh) 应用程序的控件开发方法、装置及电子设备
CN111625326A (zh) 任务管线执行方法、装置及电子设备
CN110609728A (zh) 页面生成方法、装置及电子设备
CN113448550B (zh) 实现类的收集管理方法、装置、电子设备及计算机介质
CN112445517B (zh) 入口文件生成方法、装置、电子设备和计算机可读介质
CN117112500B (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