接口转接方法、装置、电子设备及存储介质与流程

文档序号:32004885发布日期:2022-11-02 12:44阅读:46来源:国知局
接口转接方法、装置、电子设备及存储介质与流程

1.本发明涉及软件技术领域,具体而言,涉及一种接口转接方法、装置、电子设备及存储介质。


背景技术:

2.软件系统之间经常会互相调用,信息互动,能力互通。为了实现互相调用,往往会使用程序化接口(application programming interface,api)。其中,专门为外部其他软件提供的程序化接口称为开放接口(openapi)。
3.目前,api的描述通常采用开放接口规范(openapi specification,oas)。oas是一种通用的、和编程语言无关的api描述规范,使人类和计算机都可以发现和理解服务的功能,而无需访问源代码、文档或针对接口进行嗅探。
4.现有的开放接口虽然可以支持oas,但是不同开放接口之间仍需要通过开放接口网关进行调用。但是,现有的开放接口网关无法提供不同系统之间开放接口的调用。


技术实现要素:

5.基于上述现有技术存在的开放接口网关无法提供不同系统之间开放接口的调用的问题,本发明实施例提供一种接口转接方法、装置、电子设备及存储介质,可以使得不同系统之间能够互相调用开放接口。
6.第一方面,本发明实施例提供一种接口转接方法,所述方法包括:通过接口管理模块接收提供方客户端发送的开放接口的注册信息,根据所述注册信息注册所述开放接口。通过网关模块接收消费方客户端开放接口的调用信息,根据所述调用信息,从已注册的开放接口中确定待调用的开放接口。通过所述接口管理模块将所述待调用的开放接口提供给所述消费方客户端。
7.一些实施方式中,在所述根据所述注册信息注册所述开放接口之后,还包括:根据注册的所有开放接口生成标准接口文档。将所述标准接口文档通过所述接口管理模块发送给所述消费方客户端。
8.一些实施方式中,所述调用信息包括调用接口的名称、所述消费方客户端的认证信息。
9.所述通过网关模块接收消费方客户端开放接口的调用信息,根据所述调用信息,从已注册的开放接口中确定待调用的开放接口,包括:根据消费方客户端的认证信息,认证消费方客户端。根据调用接口的名称、参数,从已注册的开放接口中确定待调用的开放接口。确认消费方客户端具有调用待调用的开放接口权限。
10.一些实施方式中,所述通过所述接口管理模块将所述待调用的开放接口提供给所述消费方客户端,包括:通过所述接口管理模块将所述待调用的开放接口对应的软件开发工具包提供给所述消费方客户端。
11.一些实施方式中,所述根据所述注册信息注册所述开放接口,包括:接口管理模块
根据注册信息注册开放接口,将开放接口添加至标准接口文档,生成开放接口对应的软件开发工具包。网关模块根据注册信息将开放接口注册至路由表。测试开放接口。
12.第二方面,本发明实施例还提供一种接口转接装置,所述装置包括:接收模块,用于通过接口管理模块接收提供方客户端发送的开放接口的注册信息,根据所述注册信息注册所述开放接口;确定模块,用于通过网关模块接收消费方客户端开放接口的调用信息,根据所述调用信息,从已注册的开放接口中确定待调用的开放接口;接口模块,用于通过所述接口管理模块将所述待调用的开放接口提供给所述消费方客户端。
13.一些实施方式中,所述装置还包括生成模块,用于根据注册的所有开放接口生成接口文档;将所述标准接口文档通过所述标准接口管理模块发送给所述消费方客户端。
14.一些实施方式中,所述调用信息包括调用接口的名称、所述消费方客户端的认证信息;所述确定模块,具体用于包括:根据消费方客户端的认证信息,认证消费方客户端。根据调用接口的名称、参数,从已注册的开放接口中确定待调用的开放接口。确认消费方客户端具有调用待调用的开放接口权限。
15.一些实施方式中,接口模块,具体用于通过所述接口管理模块将所述待调用的开放接口对应的软件开发工具包提供给所述消费方客户端。
16.一些实施方式中,接收模块,具体用于接口管理模块根据注册信息注册开放接口,将开放接口添加至标准接口文档,生成开放接口对应的软件开发工具包。网关模块根据注册信息将开放接口注册至路由表。测试开放接口。
17.第三方面,本发明实施例提供一种电子设备,包括:处理器、存储介质和总线,存储介质存储有处理器可执行的机器可读指令,当电子设备运行时,处理器与存储介质之间通过总线通信,处理器执行机器可读指令,以执行时执行如第一方面提供的方法。
18.第四方面,本发明实施例提供一种存储介质,存储介质上存储有计算机程序,计算机程序被处理器运行时执行如第一方面提供的方法。
19.本发明实施例中,通过接口管理模块接收提供方客户端发送的开放接口的注册信息,根据注册信息注册开放接口。通过网关模块接收消费方客户端开放接口的调用信息,根据调用信息,从已注册的开放接口中确定待调用的开放接口。通过接口管理模块将待调用的开放接口提供给消费方客户端,实现了在不同系统之间能够互相调用开放接口。
附图说明
20.为了更清楚地说明本技术实施例中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本技术的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
21.图1是本技术一实施例提供的接口转接方法的流程示意图;
22.图2是本技术另一实施例提供的接口转接方法的流程示意图;
23.图3是本技术实施例提供的接口转接装置的结构示意图;
24.图4是本技术实施例提供的电子设备的结构示意图。
具体实施方式
25.以下描述中,为了说明而不是为了限定,提出了诸如特定系统结构、技术之类的具体细节,以便透彻理解本技术实施例。然而,本领域的技术人员应当清楚,在没有这些具体细节的其它实施例中也可以实现本技术。在其它情况中,省略对众所周知的系统、装置、电路以及方法的详细说明,以免不必要的细节妨碍本技术的描述。
26.还应当理解,在本技术说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
27.在本技术说明书中描述的参考“一些实施方式”或“一个可能的实施方式”等意味着在本技术的一个或多个实施方式中包括结合该实施例描述的特定特征、结构或特点。由此,在本说明书中的不同之处出现的语句“在一个实施方式中”、“在一些实施方式中”、“在其他一些实施方式中”、“在另外一些实施方式中”、“在一个可能的实施方式中”等不是必然都参考相同的实施例,而是意味着“一个或多个但不是所有的实施例”,除非是以其他方式另外特别强调。术语“包括”、“包含”、“具有”及它们的变形都意味着“包括但不限于”,除非是以其他方式另外特别强调。
28.本技术实施例提供的接口转接方法可以应用于服务器等电子设备上,本技术实施例对电子设备的具体类型不作任何限制。
29.图1示出了本技术一实施例提供的接口转接方法的流程示意图,作为示例而非限定,该方法可以应用于上述电子设备中。
30.如图1所示,本技术实施例提供的接口转接方法包括:
31.s11、通过接口管理模块接收提供方客户端发送的开放接口的注册信息,根据注册信息注册开放接口。
32.一些实施方式中,本技术提供的方法应用于程序应用接口中心(application programming interface hub,apihub)。apihub包括接口管理模块(manager)、客户端(client)、以及网关模块(gateway),其中,客户端包括提供方客户端(provider client)和消费方客户端(consumer client)。
33.一些实施方式中,提供方客户端可以集成在接口管理模块中,在接口管理模块中注册发布开放接口时,可以通过提供方客户端实现,即通过提供方客户端发布开放接口。
34.一些实施方式中,接口管理模块可以接受来自提供方客户端的注册信息(如api的描述文件),并根据注册信息将开放接口(open application programming interface,openapi)在接口管理模块中注册。
35.一些实施方式中,接口管理模块中注册的开放接口可以提供消息动态通知、可视化展示、在线运行调试等功能。
36.一些实施方式中,可以监控每个注册的开放接口的状态。如定时按照规范测试全量开放接口,输出测试报告。
37.当在测试时确定开放接口状态异常,则可以根据开放接口的名称、参数,确定该开放接口对应的提供方客户端,向该提供方客户端发送告警信息,以提醒提供方及时修复,保证下游业务正常。
38.s12、通过网关模块接收消费方客户端开放接口的调用信息,根据调用信息,从已注册的开放接口中确定待调用的开放接口。
39.一些实施方式中,网关模块可以自动生成路由表并支持动态刷新。同时,网关模块还可以对消费方客户端进行身份认证、数据鉴权、隐私加密、脱敏等。网关模块还可以提供模拟(mock)服务。例如,网关模块中可以包括安全模块,用于请求限流、添加网际互连协议(internet protocol,ip)地址的白名单以及提供内网/公网认证。网关模块还可以提供服务裁剪,即为不同的消费方客户端设置不同的访问等级。每个访问等级可以显示的数据范围不同。
40.一些实施方式中,调用信息包括调用接口的名称、消费方客户端的认证信息。
41.通过网关模块接收消费方客户端开放接口的调用信息,根据调用信息,从已注册的开放接口中确定待调用的开放接口,包括:根据消费方客户端的认证信息,认证消费方客户端。根据调用接口的名称、参数,从已注册的开放接口中确定待调用的开放接口。确认消费方客户端具有调用待调用的开放接口权限。
42.例如,在开放接口注册时,可以设置白名单。在消费方客户端经过认证后,可以获取待调用的开放接口对应的白名单,若消费方客户端在白名单内,则确认消费方客户端具有调用待调用的开放接口权限。
43.或者,在开放接口注册时,可以设置黑名单。在消费方客户端经过认证后,可以获取待调用的开放接口对应的黑名单,若消费方客户端不在黑名单内,则确认消费方客户端具有调用待调用的开放接口权限。
44.s13、通过接口管理模块将待调用的开放接口提供给消费方客户端。
45.一些实施方式中,可以通过通过接口管理模块将待调用的开放接口对应的软件开发工具包(software development kit,sdk)提供给所述消费方客户端。消费方不再需要对接繁琐的超文本传输协议(hyper text transfer protocol,http)接口,直接调用sdk即可实现开放接口调用。
46.在本技术中,通过接口管理模块接收提供方客户端发送的开放接口的注册信息,根据注册信息注册开放接口。通过网关模块接收消费方客户端开放接口的调用信息,根据调用信息,从已注册的开放接口中确定待调用的开放接口。通过接口管理模块将待调用的开放接口提供给消费方客户端,实现了在不同系统之间能够互相调用开放接口。
47.一些实施方式中,在所述根据所述注册信息注册所述开放接口之后,还包括:根据注册的所有开放接口生成标准接口文档。将标准接口文档通过接口管理模块发送给消费方客户端。
48.一些实施方式中,标准接口文档中记录了注册的开放接口。消费方客户端在接收到标准接口文档后,可以将标准接口文档中记录的开放接口展示出来,以便于消费方选择。
49.图2示出了本技术另一实施例提供的接口转接方法的流程示意图,作为示例而非限定,该方法可以应用于上述电子设备中。
50.一些实施方式中,如图2所示,根据注册信息注册开放接口,包括:
51.s21、接口管理模块根据注册信息注册开放接口,将开放接口添加至标准接口文档,生成开放接口对应的软件开发工具包。
52.一些实施方式中,根据注册信息注册开放接口时,可以包括通过手动、批量或者自动导入等方式。
53.手动即手动定义,与邮差(postman)接口类似,通过系统提供的页面接收用户的信
息,手动定义开放接口。
54.批量即批量导入,兼容实现了oas规范的工具,用户可以将之前用postman管理的接口批量导出再倒入到apihub里,实现批量接口定义。
55.自动导入则是提供方客户端引入apihub提供的sdk,sdk将自动发布开放接口的标准描述文件。
56.当开放接口注册后,接口管理模块可以提供对应的sdk以调用该开放接口。
57.一些实施方式中,接口管理模块还可以自动更新生成标准接口文档。每当注册一个新的开放接口,需要及时更一次新标准接口文档。
58.s22、网关模块根据注册信息将开放接口注册至路由表。
59.一些实施方式中,路由表记录了每个开放接口对应的地址,将开放接口注册至路由表后,即可生成该开放接口sdk对应的地址。
60.s23、测试开放接口。
61.一些实施方式中,接口管理模块还可以对新注册的开放接口进行测试,输出测试报告。
62.可选的,接口管理模块可以每隔预设时长进行一次所有开放接口的测试,并输出测试报告,以保证注册的所有开放接口均有效。
63.可选的,在本技术提供的方法运行过程中,会产生大量过程数据,例如,应用的健康状态、接口的调用日志、错误率等。可以根据这些过程数据实现一些扩展功能,如调用统计、错误率统计、监控告警、健康报告、价值统计等。
64.在本技术中,通过以上方式,提供了一种成体系的全链路解决问题开放接口网关的业务场景。本方法的业务改造量少。为消费方和提供方都研发了高效的sdk,引入后只有极少量配置工作。在初期只需少量人工干预,之后全部自动化,程序化自动执行高效、稳定。由于使用了行业标准(oas)故可以兼容主流的三方工具,例如postman,apifox等。
65.应理解,上述实施例中各步骤的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本技术实施例的实施过程构成任何限定。
66.对应于上文实施例的接口转接方法,图3示出了与之对应的接口转接装置的结构示意图,为了便于说明,仅示出了与本技术实施例相关的部分。
67.参照图3,该装置包括:
68.接收模块31,用于通过接口管理模块接收提供方客户端发送的开放接口的注册信息,根据注册信息注册开放接口。
69.确定模块32,用于通过网关模块接收消费方客户端开放接口的调用信息,根据调用信息,从已注册的开放接口中确定待调用的开放接口。
70.接口模块33,用于通过接口管理模块将待调用的开放接口提供给消费方客户端。
71.一些实施方式中,装置还包括生成模块34,用于根据注册的所有开放接口生成标准接口文档;将标准接口文档通过接口管理模块发送给消费方客户端。
72.一些实施方式中,调用信息包括调用接口的名称、消费方客户端的认证信息。确定模块32,具体用于根据消费方客户端的认证信息,认证消费方客户端。根据调用接口的名称、参数,从已注册的开放接口中确定待调用的开放接口。确认消费方客户端具有调用待调
用的开放接口权限。
73.一些实施方式中,接口模块33,具体用于通过接口管理模块将待调用的开放接口对应的软件开发工具包提供给消费方客户端。
74.一些实施方式中,接收模块31,具体用于接口管理模块根据注册信息注册开放接口,将开放接口添加至标准接口文档,生成开放接口对应的软件开发工具包。网关模块根据注册信息将开放接口注册至路由表。测试开放接口。。
75.需要说明的是,上述装置中模块之间的信息交互、执行过程等内容,由于与本技术方法实施例基于同一构思,其具体功能及带来的技术效果,具体可参见方法实施例部分,此处不再赘述。
76.所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,仅以上述各功能单元、模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能单元、模块完成,即将所述装置的内部结构划分成不同的功能单元或模块,以完成以上描述的全部或者部分功能。实施例中的各功能单元、模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中,上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。另外,各功能单元、模块的具体名称也只是为了便于相互区分,并不用于限制本技术的保护范围。上述系统中单元、模块的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
77.本技术实施例还提供了一种电子设备,图4示出了电子设备的结构示意图。
78.如图4所示,电子设备4包括存储器42、处理器41以及存储在存储器4中并可在处理器41上运行的计算机程序43,处理器41执行计算机程序43时实现上述的接口转接方法。
79.处理器41可以是中央处理单元(central processing unit,cpu),该处理器41还可以是其他通用处理器、数字信号处理器(digital signal processor,dsp)、专用集成电路(application specific integrated circuit,asic)、现成可编程门阵列(field-programmable gate array,fpga)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
80.存储器42在一些实施例中可以是电子设备4的内部存储单元,例如电子设备4的硬盘、闪存或内存。存储器42在另一些实施例中也可以是电子设备4的外部存储设备,例如电子设备4上配备的插接式硬盘,智能存储卡(smart media card,smc),安全数字(secure digital,sd)卡,闪存卡(flash card)等。进一步地,存储器42还可以既包括电子设备4的内部存储单元也包括外部存储设备。存储器42用于存储操作系统、应用程序、引导装载程序(bootloader)、数据以及其他程序等,例如计算机程序43的程序代码、视频等。存储器42还可以用于暂时地存储已经输出或者将要输出的数据。
81.本技术实施例还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现可实现上述各个方法实施例中的步骤。
82.本技术实施例提供了一种计算机程序产品,当计算机程序产品在移动终端上运行时,使得移动终端执行时实现可实现上述各个方法实施例中的步骤。
83.所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用
时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本技术实现上述实施例方法中的全部或部分流程,可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。其中,所述计算机程序包括计算机程序代码,所述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读介质至少可以包括:能够将计算机程序代码携带到拍照装置/终端设备的任何实体或装置、记录介质、计算机存储器、只读存储器(rom,read-only memory)、随机存取存储器(ram,random access memory)、电载波信号、电信信号以及软件分发介质。例如u盘、移动硬盘、磁碟或者光盘等。在某些司法管辖区,根据立法和专利实践,计算机可读介质不可以是电载波信号和电信信号。
84.在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述或记载的部分,可以参见其它实施例的相关描述。
85.本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本技术的范围。
86.在本技术所提供的实施例中,应该理解到,所揭露的装置/电子设备和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通讯连接可以是通过一些接口,装置或单元的间接耦合或通讯连接,可以是电性,机械或其它的形式。
87.所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
88.以上所述实施例仅用以说明本技术的技术方案,而非对其限制;尽管参照前述实施例对本技术进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本技术各实施例技术方案的精神和范围,均应包含在本技术的保护范围之内。
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1