CN109254808A - 接口调用方法、装置及计算机可读存储介质 - Google Patents
接口调用方法、装置及计算机可读存储介质 Download PDFInfo
- Publication number
- CN109254808A CN109254808A CN201810791995.6A CN201810791995A CN109254808A CN 109254808 A CN109254808 A CN 109254808A CN 201810791995 A CN201810791995 A CN 201810791995A CN 109254808 A CN109254808 A CN 109254808A
- Authority
- CN
- China
- Prior art keywords
- interface
- base class
- report
- dynamic proxy
- management system
- 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.)
- Pending
Links
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/44—Arrangements for executing specific programs
- G06F9/448—Execution paradigms, e.g. implementations of programming paradigms
- G06F9/4488—Object-oriented
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)
Abstract
本发明公开了一种接口调用方法,该方法包括:报表下发系统从报表管理系统获取通用Servlet接口的路径信息;报表下发系统确定待调用的方法,创建该方法的动态代理基类,并实例化动态代理基类;根据路径信息调用通用Servlet接口,将实例化后的动态代理基类发送至通用Servlet接口;报表管理系统通过通用Servlet接口获取实例化的动态代理基类,根据实例化的动态代理基类执行待调用的方法,将执行结果发送至报表下发系统。本发明还提出一种接口调用装置以及一种计算机可读存储介质。本发明解决了报表管理系统处代码冗余,且对于报表下发系统的接口调用的处理效率低下的技术问题。
Description
技术领域
本发明涉及计算机技术领域,尤其涉及一种接口调用方法、装置及计算机可读存储介质。
背景技术
报表管理系统用于报表BI(Business Intelligence,商业智能)数据源管理、报表管理、任务管理、日志管理等功能;报表下发系统用于报表数据的查询、下载、定时采集任务数据的下发。报表管理系统为分布式系统,当报表下发系统需要从报表管理系统调用BI源、报表等数据时,通过报表管理系统提供给外部的接口实现数据的获取。
常规的做法是:报表管理系统通过servlet提供接口给外部调用;报表下发系统通过httpclient调用报表管理系统提供的接口返回需要的数据。这种方法的缺点在于:当报表下发系统频繁调用报表管理系统的多个接口时,报表管理系统需要提供多个接口,报表下发系统需要频繁的写方法利用httpclient去调用接口,导致报表管理系统处代码冗余,且对于报表下发系统的接口调用的处理效率低下。
发明内容
本发明提供一种接口调用方法、装置及计算机可读存储介质,其主要目的在于解决报表管理系统处代码冗余,且对于报表下发系统的接口调用的处理效率低下的技术问题。
为实现上述目的,本发明还提供一种接口调用方法,该方法包括:
所述报表下发系统从所述报表管理系统获取通用Servlet接口的路径信息;
所述报表下发系统确定待调用的方法,创建该方法的动态代理基类,并实例化所述动态代理基类;
根据所述路径信息调用所述通用Servlet接口,将实例化后的动态代理基类发送至所述通用Servlet接口;
所述报表管理系统通过所述通用Servlet接口获取实例化的动态代理基类,根据所述实例化的动态代理基类执行所述待调用的方法,将执行结果发送至所述报表下发系统。
可选地,所述报表下发系统确定待调用的方法,创建该方法的动态代理基类,并实例化所述动态代理基类的步骤包括:
所述报表下发系统确定待调用的方法;
创建该方法的动态代理基类,并在所述动态代理基类中为所述方法添加预先创建的自定义注解;
根据所述自定义注解将所述动态代理基类实例化。
可选地,所述根据所述自定义注解将所述动态代理基类实例化的步骤包括:
所述报表下发系统初始化httpclientbean,对所述httpclientbean中所有方法字段进行扫描,以确定添加了所述自定义注解的方法;
为添加了所述自定义注解的方法的动态代理基类设置实例参数,以将所述动态代理基类实例化,所述实例参数包括方法名、参数值和参数类型。
可选地,所述报表管理系统通过所述通用Servlet接口获取实例化的动态代理基类,根据所述实例化的动态代理基类执行所述待调用的方法,将执行结果发送至所述报表下发系统的步骤包括:
所述报表管理系统通过所述通用Servlet接口获取实例化的动态代理基类,获取所述待调用的方法的参数,其中,所述方法的参数包括方法名、参数值和参数类型;
根据获取的方法的参数执行对应的方法,将执行结果发送至所述报表下发系统。
可选地,所述报表下发系统从所述报表管理系统获取通用Servlet接口的路径信息的步骤包括:
所述报表下发系统向所述报表管理系统发送接口信息获取请求;
所述报表管理系统根据所述接口信息获取请求,将所述接口配置文件下发至所述报表下发系统;
所述报表下发系统根据所述接口配置文件获取所述报表管理系统的通用Servlet接口的路径信息。
此外,为实现上述目的,本发明还提供一种接口调用装置,该装置包括存储器和处理器,所述存储器中存储有可在所述处理器上运行的接口调用程序,所述接口调用程序被所述处理器执行时实现如下步骤:
从所述报表管理系统获取通用Servlet接口的路径信息;
确定待调用的方法,创建该方法的动态代理基类,并实例化所述动态代理基类;
根据所述路径信息调用所述通用Servlet接口,将实例化后的动态代理基类发送至所述通用Servlet接口,以供所述报表管理系统通过所述通用Servlet接口获取实例化的动态代理基类,并根据所述实例化的动态代理基类执行所述待调用的方法,将执行结果发送至所述接口调用装置;
接收所述报表管理系统发送的执行结果。
可选地,所述确定待调用的方法,创建该方法的动态代理基类,并实例化所述动态代理基类的步骤包括:
确定待调用的方法;
创建该方法的动态代理基类,并在所述动态代理基类中为所述方法添加预先创建的自定义注解;
根据所述自定义注解将所述动态代理基类实例化。
可选地,所述根据所述自定义注解将所述动态代理基类实例化的步骤包括:
初始化httpclientbean,对所述httpclientbean中所有方法字段进行扫描,以确定添加了所述自定义注解的方法;
为添加了所述自定义注解的方法的动态代理基类设置实例参数,以将所述动态代理基类实例化,所述实例参数包括方法名、参数值和参数类型。
可选地,所述从所述报表管理系统获取通用Servlet接口的路径信息的步骤包括:
向所述报表管理系统发送接口信息获取请求,其中,所述报表管理系统根据所述接口信息获取请求,将所述接口配置文件下发至所述报表下发系统;
根据所述接口配置文件获取所述报表管理系统的通用Servlet接口的路径信息。
此外,为实现上述目的,本发明还提供一种计算机可读存储介质,所述计算机可读存储介质上存储有接口调用程序,所述接口调用程序可被一个或者多个处理器执行,以实现如上所述的接口调用方法的步骤。
本发明提出的接口调用方法、装置及计算机可读存储介质,报表下发系统从报表管理系统获取通用Servlet接口的路径信息;报表下发系统确定待调用的方法,创建该方法的动态代理基类,并实例化动态代理基类;根据路径信息调用通用Servlet接口,将实例化后的动态代理基类发送至通用Servlet接口;报表管理系统通过通用Servlet接口获取实例化的动态代理基类,根据实例化的动态代理基类执行待调用的方法,将执行结果发送至报表下发系统。本发明的方案中,报表管理系统不需要实现多个接口方法,只需要实现一个通用Servlet接口即可,报表下发系统获取到该接口的路径信息,根据路径信息访问该接口,并通过动态代理的方式将要调用的具体的方法的相关参数上传到该接口,进而实现方法执行结果的获取,不需要频繁的写HttpClient调用远程接口具体实现方法,不仅简化了代码,而且提高了接口调用的处理效率。
附图说明
图1为本发明一实施例提供的接口调用方法的流程示意图;
图2为本发明一实施例提供的接口调用装置的内部结构示意图;
图3为本发明一实施例提供的接口调用装置中接口调用程序的模块示意图。
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
本发明提供一种接口调用方法。参照图1所示,为本发明一实施例提供的接口调用方法的流程示意图。该方法可以由一个装置执行,该装置可以由软件和/或硬件实现。
在本实施例中,接口调用方法包括:
步骤S10,所述报表下发系统从所述报表管理系统获取通用Servlet接口的路径信息。
本发明实施例中主要包括报表管理系统和报表下发系统,报表管理系统和报表下发系统之间建立远程通讯连接,其中,报表管理系统主要用于报表BI数据源管理、报表管理、任务管理、日志管理等功能。报表下发系统主要用于报表数据的查询、下载、定时采集任务数据的下发。报表管理系统为分布式系统,当报表下发系统需要从报表管理系统调用BI数据源、报表等数据时,通过报表管理系统提供给外部的接口实现数据的获取。
报表管理系统配置好通用Servlet接口以及接口配置文件;通过接口配置文件配置相应的servlet请求对应的路径信息。该路径信息主用于表下发系统调用远程报表管理系统的接口方法时能找到报表管理系统通用的动态代理处理方法,报表下发系统根据暴露的接口的路径信息查找对应的上述通用Servlet接口。其中,报表管理系统可以主动将该接口配置文件下发到报表下发系统,报表下发系统从该文件中获取路径信息。或者,在其他实施例中,报表下发系统从所述报表管理系统获取通用Servlet接口的路径信息的步骤包括:所述报表下发系统向所述报表管理系统发送接口信息获取请求;所述报表管理系统根据所述接口信息获取请求,将所述接口配置文件下发至所述报表下发系统;所述报表下发系统根据所述接口配置文件获取所述报表管理系统的通用Servlet接口的路径信息。具体地,报表下发系统通过httpclient访问报表管理系统的通用Servlet接口的配置文件,以获取该通用Servlet接口的路径信息,通过路径信息调用报表管理系统的servlet方法。
关于报表管理系统设置的通用Servlet接口,此处可以理解为接口的代理,在确定方法名、参数类型以及参数值后,就可以通过反射机制在报表下发系统调用远程服务器端的具体方法,并由远程服务器端返回执行具体方法的结果数据给报表下发系统。
步骤S20,所述报表下发系统确定待调用的方法,创建该方法的动态代理基类,并实例化所述动态代理基类。
步骤S30,根据所述路径信息调用所述通用Servlet接口,将实例化后的动态代理基类发送至所述通用Servlet接口。
具体地,报表下发系统确定待调用的方法,创建该方法的动态代理基类,并实例化所述动态代理基类的步骤包括:所述报表下发系统确定待调用的方法;创建该方法的动态代理基类,并在所述动态代理基类中为所述方法添加预先创建的自定义注解;根据所述自定义注解将所述动态代理基类实例化。
报表下发系统预先自定义注解@HttpService。在需要向报表管理系统请求执行具体的方法时,先确定待调用的具体方法,创建该方法的动态代理基类ServiceProxyDTO,并在动态代理基类中为所述方法添加预先创建的自定义注解@HttpService,基于spring框架创建httpclientbean,Spring的后置处理器HttpServiceBeanProxyProcessor将其初始化,然后对httpclientbean中的所有方法字段进行扫描,判断方法是否添加了上述自定义注解@HttpService,当通过扫描找到添加了自定义注解@HttpService的方法后,实例化该方法的动态基类ServiceProxyDTO的实例名,方法名,参数值,参数类型等具体实例参数值。将实例化后的动态代理基类ServiceProxyDTO作为参数,通过Httpclient传到报表管理系统的通用servlet接口里面去。
步骤S40,所述报表管理系统通过所述通用Servlet接口获取实例化的动态代理基类,根据所述实例化的动态代理基类执行所述待调用的方法,将执行结果发送至所述报表下发系统。
报表管理系统通过servlet接口获取到报表下发系统传入的实例化后的动态代理基类ServiceProxyDTO,通过实例化后的动态代理基类ServiceProxyDTO获取需要调用的方法名,参数类型以及参数值;然后基于获取的上述数据,通过反射method.invoke方法调用执行报表管理系统对应的具体方法,并实现该具体方法,将执行的具体结果返回到报表下发系统。从上述方案中可以看出报表管理系统处只需要设置一个通用的Servlet接口即可,在需要调用报表管理系统处的具体的方法时,基于动态代理类将该方法的参数上传到上述通用的Servlet接口,以实现调用报表管理系统的具体方法。报表管理系统无需维护过多接口的代码,报表下发系统不需要频繁的写方法利用httpclient去调用接口,提高了接口调用的处理效率。
本实施例提出的接口调用方法,报表下发系统从报表管理系统获取通用Servlet接口的路径信息;报表下发系统确定待调用的方法,创建该方法的动态代理基类,并实例化动态代理基类;根据路径信息调用通用Servlet接口,将实例化后的动态代理基类发送至通用Servlet接口;报表管理系统通过通用Servlet接口获取实例化的动态代理基类,根据实例化的动态代理基类执行待调用的方法,将执行结果发送至报表下发系统。本发明的方案中,报表管理系统不需要实现多个接口方法,只需要实现一个通用Servlet接口即可,报表下发系统获取到该接口的路径信息,根据路径信息访问该接口,并通过动态代理的方式将要调用的具体的方法的相关参数上传到该接口,进而实现方法执行结果的获取,不需要频繁的写HttpClient调用远程接口具体实现方法,不仅简化了代码,而且提高了接口调用的处理效率。
本发明还提供一种接口调用装置。参照图2所示,为本发明一实施例提供的接口调用装置的内部结构示意图。
在本实施例中,接口调用装置1可以是PC(Personal Computer,个人电脑),也可以是智能手机、平板电脑、便携计算机等终端设备。该接口调用装置1至少包括存储器11、处理器12,网络接口13以及通信总线。
其中,存储器11至少包括一种类型的可读存储介质,所述可读存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,SD或DX存储器等)、磁性存储器、磁盘、光盘等。存储器11在一些实施例中可以是接口调用装置1的内部存储单元,例如该接口调用装置1的硬盘。存储器11在另一些实施例中也可以是接口调用装置1的外部存储设备,例如接口调用装置1上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(Flash Card)等。进一步地,存储器11还可以既包括接口调用装置1的内部存储单元也包括外部存储设备。存储器11不仅可以用于存储安装于接口调用装置1的应用软件及各类数据,例如接口调用程序01的代码等,还可以用于暂时地存储已经输出或者将要输出的数据。
处理器12在一些实施例中可以是一中央处理器(Central Processing Unit,CPU)、控制器、微控制器、微处理器或其他数据处理芯片,用于运行存储器11中存储的程序代码或处理数据,例如执行接口调用程序01等。
网络接口13可选的可以包括标准的有线接口、无线接口(如WI-FI接口),通常用于在该装置1与其他电子设备之间建立通信连接。
通信总线用于实现这些组件之间的连接通信。
可选地,该装置1还可以包括用户接口,用户接口可以包括显示器(Display)、输入单元比如键盘(Keyboard),可选的用户接口还可以包括标准的有线接口、无线接口。可选地,在一些实施例中,显示器可以是LED显示器、液晶显示器、触控式液晶显示器以及OLED(Organic Light-Emitting Diode,有机发光二极管)触摸器等。其中,显示器也可以适当的称为显示屏或显示单元,用于显示在接口调用装置1中处理的信息以及用于显示可视化的用户界面。
图2仅示出了具有组件11-13以及接口调用程序01的接口调用装置1,本领域技术人员可以理解的是,图1示出的结构并不构成对接口调用装置1的限定,可以包括比图示更少或者更多的部件,或者组合某些部件,或者不同的部件布置。
在图2所示的装置1实施例中,存储器11中存储有接口调用程序01;处理器12执行存储器11中存储的接口调用程序01时实现如下步骤:
所述报表下发系统从所述报表管理系统获取通用Servlet接口的路径信息。
所述报表下发系统确定待调用的方法,创建该方法的动态代理基类,并实例化所述动态代理基类。
根据所述路径信息调用所述通用Servlet接口,将实例化后的动态代理基类发送至所述通用Servlet接口。
所述报表管理系统通过所述通用Servlet接口获取实例化的动态代理基类,根据所述实例化的动态代理基类执行所述待调用的方法,将执行结果发送至所述报表下发系统。
本发明实施例中主要包括报表管理系统和报表下发系统,报表管理系统和报表下发系统之间建立远程通讯连接,其中,报表管理系统主要用于报表BI数据源管理、报表管理、任务管理、日志管理等功能。报表下发系统主要用于报表数据的查询、下载、定时采集任务数据的下发。报表管理系统为分布式系统,当报表下发系统需要从报表管理系统调用BI数据源、报表等数据时,通过报表管理系统提供给外部的接口实现数据的获取。
报表管理系统配置好通用Servlet接口以及接口配置文件;通过接口配置文件配置相应的servlet请求对应的路径信息。该路径信息主用于表下发系统调用远程报表管理系统的接口方法时能找到报表管理系统通用的动态代理处理方法,报表下发系统根据暴露的接口的路径信息查找对应的上述通用Servlet接口。其中,报表管理系统可以主动将该接口配置文件下发到报表下发系统,报表下发系统从该文件中获取路径信息。或者,在其他实施例中,报表下发系统从所述报表管理系统获取通用Servlet接口的路径信息的步骤包括:所述报表下发系统向所述报表管理系统发送接口信息获取请求;所述报表管理系统根据所述接口信息获取请求,将所述接口配置文件下发至所述报表下发系统;所述报表下发系统根据所述接口配置文件获取所述报表管理系统的通用Servlet接口的路径信息。具体地,报表下发系统通过httpclient访问报表管理系统的通用Servlet接口的配置文件,以获取该通用Servlet接口的路径信息,通过路径信息调用报表管理系统的servlet方法。
关于报表管理系统设置的通用Servlet接口,此处可以理解为接口的代理,在确定方法名、参数类型以及参数值后,就可以通过反射机制在报表下发系统调用远程服务器端的具体方法,并由远程服务器端返回执行具体方法的结果数据给报表下发系统。
具体地,报表下发系统确定待调用的方法,创建该方法的动态代理基类,并实例化所述动态代理基类的步骤包括:所述报表下发系统确定待调用的方法;创建该方法的动态代理基类,并在所述动态代理基类中为所述方法添加预先创建的自定义注解;根据所述自定义注解将所述动态代理基类实例化。
报表下发系统预先自定义注解@HttpService。在需要向报表管理系统请求执行具体的方法时,先确定待调用的具体方法,创建该方法的动态代理基类ServiceProxyDTO,并在动态代理基类中为所述方法添加预先创建的自定义注解@HttpService,基于spring框架创建httpclientbean,Spring的后置处理器HttpServiceBeanProxyProcessor将其初始化,然后对httpclientbean中的所有方法字段进行扫描,判断方法是否添加了上述自定义注解@HttpService,当通过扫描找到添加了自定义注解@HttpService的方法后,实例化该方法的动态基类ServiceProxyDTO的实例名,方法名,参数值,参数类型等具体实例参数值。将实例化后的动态代理基类ServiceProxyDTO作为参数,通过Httpclient传到报表管理系统的通用servlet接口里面去。
报表管理系统通过servlet接口获取到报表下发系统传入的实例化后的动态代理基类ServiceProxyDTO,通过实例化后的动态代理基类ServiceProxyDTO获取需要调用的方法名,参数类型以及参数值;然后基于获取的上述数据,通过反射method.invoke方法调用执行报表管理系统对应的具体方法,并实现该具体方法,将执行的具体结果返回到报表下发系统。
从上述方案中可以看出报表管理系统处只需要设置一个通用的Servlet接口即可,在需要调用报表管理系统处的具体的方法时,基于动态代理类将该方法的参数上传到上述通用的Servlet接口,以实现调用报表管理系统的具体方法。报表管理系统无需维护过多接口的代码,报表下发系统不需要频繁的写方法利用httpclient去调用接口,提高了接口调用的处理效率。
本实施例提出的接口调用装置,报表下发系统从报表管理系统获取通用Servlet接口的路径信息;报表下发系统确定待调用的方法,创建该方法的动态代理基类,并实例化动态代理基类;根据路径信息调用通用Servlet接口,将实例化后的动态代理基类发送至通用Servlet接口;报表管理系统通过通用Servlet接口获取实例化的动态代理基类,根据实例化的动态代理基类执行待调用的方法,将执行结果发送至报表下发系统。本发明的方案中,报表管理系统不需要实现多个接口方法,只需要实现一个通用Servlet接口即可,报表下发系统获取到该接口的路径信息,根据路径信息访问该接口,并通过动态代理的方式将要调用的具体的方法的相关参数上传到该接口,进而实现方法执行结果的获取,不需要频繁的写HttpClient调用远程接口具体实现方法,不仅简化了代码,而且提高了接口调用的处理效率。
可选地,在其他的实施例中,接口调用程序还可以被分割为一个或者多个模块,一个或者多个模块被存储于存储器11中,并由一个或多个处理器(本实施例为处理器12)所执行以完成本发明,本发明所称的模块是指能够完成特定功能的一系列计算机程序指令段,用于描述接口调用程序在接口调用装置中的执行过程。
例如,参照图3所示,为本发明接口调用装置一实施例中的接口调用程序的程序模块示意图,该实施例中,接口调用程序可以被分割为信息获取模块10、动态代理模块20、请求发送模块30和数据接收模块40,示例性地:
信息获取模块10用于:从所述报表管理系统获取通用Servlet接口的路径信息;
动态代理模块20用于:确定待调用的方法,创建该方法的动态代理基类,并实例化所述动态代理基类;
请求发送模块30用于:根据所述路径信息调用所述通用Servlet接口,将实例化后的动态代理基类发送至所述通用Servlet接口,以供所述报表管理系统通过所述通用Servlet接口获取实例化的动态代理基类,并根据所述实例化的动态代理基类执行所述待调用的方法,将执行结果发送至所述接口调用装置;
数据接收模块40用于:接收所述报表管理系统发送的执行结果。
上述信息获取模块10、动态代理模块20、请求发送模块30和数据接收模块40等程序模块被执行时所实现的功能或操作步骤与上述实施例大体相同,在此不再赘述。
此外,本发明实施例还提出一种计算机可读存储介质,所述计算机可读存储介质上存储有接口调用程序,所述接口调用程序可被一个或多个处理器执行,以实现如下操作:
所述报表下发系统从所述报表管理系统获取通用Servlet接口的路径信息;
所述报表下发系统确定待调用的方法,创建该方法的动态代理基类,并实例化所述动态代理基类;
根据所述路径信息调用所述通用Servlet接口,将实例化后的动态代理基类发送至所述通用Servlet接口;
所述报表管理系统通过所述通用Servlet接口获取实例化的动态代理基类,根据所述实例化的动态代理基类执行所述待调用的方法,将执行结果发送至所述报表下发系统。
本发明计算机可读存储介质具体实施方式与上述接口调用装置和方法各实施例基本相同,在此不作累述。
需要说明的是,上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。并且本文中的术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、装置、物品或者方法不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、装置、物品或者方法所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、装置、物品或者方法中还存在另外的相同要素。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在如上所述的一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,或者网络设备等)执行本发明各个实施例所述的方法。
以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。
Claims (10)
1.一种接口调用方法,其特征在于,所述方法包括:
所述报表下发系统从所述报表管理系统获取通用Servlet接口的路径信息;
所述报表下发系统确定待调用的方法,创建该方法的动态代理基类,并实例化所述动态代理基类;
根据所述路径信息调用所述通用Servlet接口,将实例化后的动态代理基类发送至所述通用Servlet接口;
所述报表管理系统通过所述通用Servlet接口获取实例化的动态代理基类,根据所述实例化的动态代理基类执行所述待调用的方法,将执行结果发送至所述报表下发系统。
2.如权利要求1所述的接口调用方法,其特征在于,所述报表下发系统确定待调用的方法,创建该方法的动态代理基类,并实例化所述动态代理基类的步骤包括:
所述报表下发系统确定待调用的方法;
创建该方法的动态代理基类,并在所述动态代理基类中为所述方法添加预先创建的自定义注解;
根据所述自定义注解将所述动态代理基类实例化。
3.如权利要求2所述的接口调用方法,其特征在于,所述根据所述自定义注解将所述动态代理基类实例化的步骤包括:
所述报表下发系统初始化httpclientbean,对所述httpclientbean中所有方法字段进行扫描,以确定添加了所述自定义注解的方法;
为添加了所述自定义注解的方法的动态代理基类设置实例参数,以将所述动态代理基类实例化,所述实例参数包括方法名、参数值和参数类型。
4.如权利要求1至3中任一项所述的接口调用方法,其特征在于,所述报表管理系统通过所述通用Servlet接口获取实例化的动态代理基类,根据所述实例化的动态代理基类执行所述待调用的方法,将执行结果发送至所述报表下发系统的步骤包括:
所述报表管理系统通过所述通用Servlet接口获取实例化的动态代理基类,获取所述待调用的方法的参数,其中,所述方法的参数包括方法名、参数值和参数类型;
根据获取的方法的参数执行对应的方法,将执行结果发送至所述报表下发系统。
5.如权利要求1至3中任一项所述的接口调用方法,其特征在于,所述报表下发系统从所述报表管理系统获取通用Servlet接口的路径信息的步骤包括:
所述报表下发系统向所述报表管理系统发送接口信息获取请求;
所述报表管理系统根据所述接口信息获取请求,将所述接口配置文件下发至所述报表下发系统;
所述报表下发系统根据所述接口配置文件获取所述报表管理系统的通用Servlet接口的路径信息。
6.一种接口调用装置,其特征在于,所述装置包括存储器和处理器,所述存储器上存储有可在所述处理器上运行的接口调用程序,所述接口调用程序被所述处理器执行时实现如下步骤:
从所述报表管理系统获取通用Servlet接口的路径信息;
确定待调用的方法,创建该方法的动态代理基类,并实例化所述动态代理基类;
根据所述路径信息调用所述通用Servlet接口,将实例化后的动态代理基类发送至所述通用Servlet接口,以供所述报表管理系统通过所述通用Servlet接口获取实例化的动态代理基类,并根据所述实例化的动态代理基类执行所述待调用的方法,将执行结果发送至所述接口调用装置;
接收所述报表管理系统发送的执行结果。
7.如权利要求6所述的接口调用装置,其特征在于,所述确定待调用的方法,创建该方法的动态代理基类,并实例化所述动态代理基类的步骤包括:
确定待调用的方法;
创建该方法的动态代理基类,并在所述动态代理基类中为所述方法添加预先创建的自定义注解;
根据所述自定义注解将所述动态代理基类实例化。
8.如权利要求7所述的接口调用装置,其特征在于,所述根据所述自定义注解将所述动态代理基类实例化的步骤包括:
初始化httpclientbean,对所述httpclientbean中所有方法字段进行扫描,以确定添加了所述自定义注解的方法;
为添加了所述自定义注解的方法的动态代理基类设置实例参数,以将所述动态代理基类实例化,所述实例参数包括方法名、参数值和参数类型。
9.如权利要求6至8中任一项所述的接口调用装置,其特征在于,所述从所述报表管理系统获取通用Servlet接口的路径信息的步骤包括:
向所述报表管理系统发送接口信息获取请求,其中,所述报表管理系统根据所述接口信息获取请求,将所述接口配置文件下发至所述报表下发系统;
根据所述接口配置文件获取所述报表管理系统的通用Servlet接口的路径信息。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有接口调用程序,所述接口调用程序可被一个或者多个处理器执行,以实现如权利要求1至5中任一项所述的接口调用方法的步骤。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810791995.6A CN109254808A (zh) | 2018-07-18 | 2018-07-18 | 接口调用方法、装置及计算机可读存储介质 |
PCT/CN2018/107724 WO2020015170A1 (zh) | 2018-07-18 | 2018-09-26 | 接口调用方法、装置及计算机可读存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810791995.6A CN109254808A (zh) | 2018-07-18 | 2018-07-18 | 接口调用方法、装置及计算机可读存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN109254808A true CN109254808A (zh) | 2019-01-22 |
Family
ID=65048682
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810791995.6A Pending CN109254808A (zh) | 2018-07-18 | 2018-07-18 | 接口调用方法、装置及计算机可读存储介质 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN109254808A (zh) |
WO (1) | WO2020015170A1 (zh) |
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110069248A (zh) * | 2019-03-16 | 2019-07-30 | 平安城市建设科技(深圳)有限公司 | 接口数据的调用方法、装置、设备及计算机可读存储介质 |
CN111191246A (zh) * | 2019-12-19 | 2020-05-22 | 杭州安恒信息技术股份有限公司 | 一种基于Spring注解的安全开发校验方法 |
CN111209122A (zh) * | 2019-12-24 | 2020-05-29 | 广州华多网络科技有限公司 | 接口调用方法、装置、电子设备及存储介质 |
CN112199092A (zh) * | 2020-09-17 | 2021-01-08 | 上海硬通网络科技有限公司 | 应用的开发方法、装置及电子设备 |
CN113608779A (zh) * | 2021-08-10 | 2021-11-05 | 平安国际智慧城市科技股份有限公司 | 服务接口配置方法、装置、设备及存储介质 |
CN114489830A (zh) * | 2021-12-23 | 2022-05-13 | 阿里巴巴(中国)有限公司 | 配置页面操作方法、处理方法和计算设备 |
CN114489830B (zh) * | 2021-12-23 | 2024-06-07 | 阿里巴巴(中国)有限公司 | 配置页面操作方法、处理方法和计算设备 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20050283517A1 (en) * | 2004-06-22 | 2005-12-22 | International Business Machines Corporation | System and method for asynchronously invoking dynamic proxy interface using supplemental interfaces |
CN101266542A (zh) * | 2008-02-01 | 2008-09-17 | 中国建设银行股份有限公司 | 一种在容器中装载组件的方法及装置 |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103425462B (zh) * | 2012-05-14 | 2016-12-14 | 阿里巴巴集团控股有限公司 | 一种工作流数据持久化的方法和装置 |
CN103152433B (zh) * | 2013-01-14 | 2017-12-05 | 广东电子工业研究院有限公司 | 一种分布式服务端的使用、交互和请求处理方法 |
CN106354481B (zh) * | 2015-07-13 | 2019-12-27 | 阿里巴巴集团控股有限公司 | 对http请求进行统一映射的方法和设备 |
CN107770225B (zh) * | 2016-08-22 | 2020-11-03 | 北京京东尚科信息技术有限公司 | 一种webService访问系统和访问webService的方法 |
CN107678864A (zh) * | 2017-01-13 | 2018-02-09 | 北京资配易投资顾问有限公司 | 接口的调用方法及系统 |
CN108234670B (zh) * | 2018-01-31 | 2021-01-15 | 北京中安智达科技有限公司 | 一种基于zookeeper和netty的分布式远程调用方法 |
-
2018
- 2018-07-18 CN CN201810791995.6A patent/CN109254808A/zh active Pending
- 2018-09-26 WO PCT/CN2018/107724 patent/WO2020015170A1/zh active Application Filing
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20050283517A1 (en) * | 2004-06-22 | 2005-12-22 | International Business Machines Corporation | System and method for asynchronously invoking dynamic proxy interface using supplemental interfaces |
CN101266542A (zh) * | 2008-02-01 | 2008-09-17 | 中国建设银行股份有限公司 | 一种在容器中装载组件的方法及装置 |
Non-Patent Citations (2)
Title |
---|
ITEYE_14360: "使用HttpClient、注解、动态代理、Spring的Bean后处理器实现Http消息发送", 《HTTPS://BLOG.CSDN.NET/ITEYE_14360/ARTICLE/DETAILS/82579699》 * |
程泽: "PBE框架下报表生成及发布系统的设计与实现", 《中国优秀硕士学位论文全文数据库 信息科技辑》 * |
Cited By (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110069248A (zh) * | 2019-03-16 | 2019-07-30 | 平安城市建设科技(深圳)有限公司 | 接口数据的调用方法、装置、设备及计算机可读存储介质 |
CN111191246A (zh) * | 2019-12-19 | 2020-05-22 | 杭州安恒信息技术股份有限公司 | 一种基于Spring注解的安全开发校验方法 |
CN111209122A (zh) * | 2019-12-24 | 2020-05-29 | 广州华多网络科技有限公司 | 接口调用方法、装置、电子设备及存储介质 |
CN111209122B (zh) * | 2019-12-24 | 2024-06-11 | 广州华多网络科技有限公司 | 接口调用方法、装置、电子设备及存储介质 |
CN112199092A (zh) * | 2020-09-17 | 2021-01-08 | 上海硬通网络科技有限公司 | 应用的开发方法、装置及电子设备 |
CN112199092B (zh) * | 2020-09-17 | 2024-03-15 | 上海硬通网络科技有限公司 | 应用的开发方法、装置及电子设备 |
CN113608779A (zh) * | 2021-08-10 | 2021-11-05 | 平安国际智慧城市科技股份有限公司 | 服务接口配置方法、装置、设备及存储介质 |
CN113608779B (zh) * | 2021-08-10 | 2023-12-26 | 平安国际智慧城市科技股份有限公司 | 服务接口配置方法、装置、设备及存储介质 |
CN114489830A (zh) * | 2021-12-23 | 2022-05-13 | 阿里巴巴(中国)有限公司 | 配置页面操作方法、处理方法和计算设备 |
CN114489830B (zh) * | 2021-12-23 | 2024-06-07 | 阿里巴巴(中国)有限公司 | 配置页面操作方法、处理方法和计算设备 |
Also Published As
Publication number | Publication date |
---|---|
WO2020015170A1 (zh) | 2020-01-23 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109254808A (zh) | 接口调用方法、装置及计算机可读存储介质 | |
CN109358851A (zh) | 图表组件的创建方法、装置及计算机可读存储介质 | |
US6968535B2 (en) | Service mapping method of enterprise application modeling and development for multi-tier service environments | |
CN107908472A (zh) | 数据同步装置、方法及计算机可读存储介质 | |
CN107656729B (zh) | 列表视图的更新装置、方法及计算机可读存储介质 | |
CA2511912A1 (en) | System and method for building and execution of platform-neutral generic services' client applications | |
CN102227901A (zh) | 点滴式同步协议 | |
CN109408136A (zh) | 信息处理方法、装置、存储介质及电子设备 | |
CN108388988A (zh) | 基于区块链的协同办公方法、系统及计算机可读存储介质 | |
CN109816481A (zh) | 账单处理方法、装置及计算机可读存储介质 | |
CN113867913A (zh) | 面向微服务的业务请求处理方法、装置、设备及存储介质 | |
CN103942055A (zh) | 面向融合网络混合服务流程编制语言的开发系统及方法 | |
CN110069248A (zh) | 接口数据的调用方法、装置、设备及计算机可读存储介质 | |
CN108874464A (zh) | 中间件自动扫描装配方法、装置及存储介质 | |
CN110647316A (zh) | 通用业务对象的生成方法、装置、计算机设备及存储介质 | |
CN110941779A (zh) | 加载页面的方法、装置、存储介质及电子设备 | |
CN1577277A (zh) | 管理程序应用 | |
CN110020060A (zh) | 网页数据爬取方法、装置及存储介质 | |
CN109241727B (zh) | 权限设置方法及装置 | |
CN116661936A (zh) | 页面数据的处理方法、装置、计算机设备及存储介质 | |
CN109766489A (zh) | 数据处理方法、客户端、服务器及计算机可读存储介质 | |
US10572531B1 (en) | Predictive session-based search engine | |
CN110334063B (zh) | 文件系统的操作方法、装置、设备及计算机可读存储介质 | |
CN110647566B (zh) | 模板表格的智能导入方法、装置及计算机可读存储介质 | |
CN113254825A (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 | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20190122 |
|
RJ01 | Rejection of invention patent application after publication |