CN107577590A - 基于数据库服务实时调用虚拟接口的方法及装置 - Google Patents

基于数据库服务实时调用虚拟接口的方法及装置 Download PDF

Info

Publication number
CN107577590A
CN107577590A CN201610519713.8A CN201610519713A CN107577590A CN 107577590 A CN107577590 A CN 107577590A CN 201610519713 A CN201610519713 A CN 201610519713A CN 107577590 A CN107577590 A CN 107577590A
Authority
CN
China
Prior art keywords
virtual interface
interface
configuration information
virtual
database
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.)
Granted
Application number
CN201610519713.8A
Other languages
English (en)
Other versions
CN107577590B (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 Qizhi Business Consulting Co ltd
Beijing Qihoo Technology Co Ltd
Original Assignee
Beijing Qihoo Technology Co Ltd
Qizhi Software Beijing 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 Qihoo Technology Co Ltd, Qizhi Software Beijing Co Ltd filed Critical Beijing Qihoo Technology Co Ltd
Priority to CN201610519713.8A priority Critical patent/CN107577590B/zh
Publication of CN107577590A publication Critical patent/CN107577590A/zh
Application granted granted Critical
Publication of CN107577590B publication Critical patent/CN107577590B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Abstract

本发明公开了一种基于数据库服务实时调用虚拟接口的方法及装置,方法包括:获取通过Web页面输入的虚拟接口的配置信息,将虚拟接口的配置信息存储在数据库中;监听客户端调用虚拟接口的请求,提取调用虚拟接口的接口地址;根据调用虚拟接口的接口地址,从数据库中查询虚拟接口的配置信息,返回对应的虚拟接口的返回值和/或响应体。本发明通过数据库对虚拟接口的配置信息进行管理,实现快速查找和调用虚拟接口,与查找、调用代码级虚拟接口所花费的时间相比,大大减少。同时通过Web页面和数据库存储的方式所建立的虚拟接口,无需进行代码编写,降低了用户对虚拟接口代码熟悉程度的要求。

Description

基于数据库服务实时调用虚拟接口的方法及装置
技术领域
本发明涉及计算机软件领域,具体涉及一种基于数据库服务实时调用虚拟接口的方法及装置。
背景技术
程序编码开发后,需要对编码的程序进行测试。测试时,相关的程序实现的功能需要进行联合测试。但由于程序开发过程中存在各种因素导致的不可控性,常常发生第一个功能的程序已经开发完成,而其需要联合测试的程序还没有开发完成,无法进行联合测试。等待需要联合测试的程序开发完成后再测试,浪费时间。或测试的程序功能受限,如一天只能测试一次、依赖外部资源交互等等,因此急需一种测试方法,实现虚拟其未完成程序功能或虚拟程序受限制部分,与完成的程序进行联合测试。
现有技术采用mock测试方法,创建一个虚拟的对象以便完成测试。在使用mock方法测试时,大多通过编写mock代码,提供代码级别的mock方法调用,建立mock对象等进行测试。如采用如EasyMock、JMock等mock工具,通过代码来编写相应的mock接口。现有技术在编写一个mock接口,并被被测试对象调用的过程一般包括以下步骤:创建mock对象、设置mock期望值、将mock对象设置给被测试的对象、调用被测试对象、被测试对象代码调用mock对象、进行验证。但以上方式限制了对mock不熟悉的用户无法通过代码编写相应的mock接口及mock对象等。同时,代码编写的虚拟接口使得用户需对代码文档进行管理,为避免最终程序无误使用还需将测试用的虚拟接口的代码文档与实际程序的代码文档进行区分。通过文档管理虚拟接口代码比较费时费力。
发明内容
鉴于上述问题,提出了本发明以便提供一种克服上述问题或者至少部分地解决上述问题的基于数据库服务实时调用虚拟接口的方法及装置。
根据本发明的一个方面,提供了一种基于数据库服务实时调用虚拟接口的方法,其包括:获取通过Web页面输入的虚拟接口的配置信息,将虚拟接口的配置信息存储在数据库中;监听客户端调用虚拟接口的请求,提取调用虚拟接口的接口地址;根据调用虚拟接口的接口地址,从数据库中查询虚拟接口的配置信息,返回对应的虚拟接口的返回值和/或响应体。
根据本发明的另一方面,提供了一种基于数据库服务实时调用虚拟接口的装置,其包括:存储模块,适于获取通过Web页面输入的虚拟接口的配置信息,将虚拟接口的配置信息存储在数据库中;监听模块,适于监听客户端调用虚拟接口的请求,提取调用虚拟接口的接口地址;数据库查询模块,适于根据调用虚拟接口的接口地址,从数据库中查询虚拟接口的配置信息;响应模块,适于返回对应的虚拟接口的返回值和/或响应体。
根据本发明所提供的基于数据库服务实时调用虚拟接口的方法及装置,获取到通过Web页面输入的虚拟接口的配置信息后,将虚拟接口的配置信息存储在数据库中。同时对客户端调用虚拟接口的请求进行监听,根据提取的调用虚拟接口的接口地址,从数据库中查询虚拟接口的配置信息,返回对应的虚拟接口的返回值和/或响应体。通过数据库对虚拟接口的配置信息进行管理,实现快速查找和调用虚拟接口,与查找、调用代码级虚拟接口所花费的时间相比,大大减少。同时通过Web页面和数据库存储的方式所建立的虚拟接口,无需进行代码编写,降低了用户对虚拟接口代码熟悉程度的要求,使更多的用户可以简单方便的使用虚拟接口进行测试。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
图1示出了根据本发明一个实施例的基于数据库服务实时调用虚拟接口的方法的流程图;
图2示出了根据本发明另一个实施例的基于数据库服务实时调用虚拟接口的方法的流程图;
图3示出了根据本发明一个实施例的基于数据库服务实时调用虚拟接口的装置的功能框图;
图4示出了根据本发明另一个实施例的基于数据库服务实时调用虚拟接口的装置的功能框图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
虚拟接口一般用于测试使用,与实际的程序接口相对,实现对实际的程序接口的虚拟。虚拟接口不涉及实际程序接口实现的具体功能,仅提供被调用的虚拟接口和根据实际程序接口调用后返回的数据类型所返回的特定的测试用的数据。如当实际程序被调用的接口还未编写完成,但调用其接口的上一层程序需要进行测试时,可使用虚拟接口对实际被调用的接口进行虚拟,上一层程序通过调用虚拟接口,完成对上一层程序的测试。或当程序的执行受到限制时,如一天仅能执行一次,或仅在特定时间内可以执行时,测试需要反复测试,一天仅测试一次显然不够,可以通过调用虚拟接口,将执行受限制的部分功能屏蔽,返回特定的数据以供测试使用。测试时,被测试对象所调用的程序接口未完成时或调用的程序受限,对被测试对象调用的程序编写对应的虚拟接口,被测试对象通过调用虚拟接口,完成测试。
图1示出了根据本发明一个实施例的基于数据库服务实时调用虚拟接口的方法的流程图。如图1所示,该方法包括以下步骤:
步骤S101,获取通过Web页面输入的虚拟接口的配置信息,将虚拟接口的配置信息存储在数据库中。
通过Web页面输入的方式,在页面中列出虚拟接口需要进行填写的配置信息,虚拟接口的配置信息包括:虚拟接口的接口地址、调用方式、返回值和/或响应体。
虚拟接口的接口地址即虚拟了真实程序接口后的虚拟接口的调用入口,若需要的虚拟接口为HTTP接口、RPC接口、SMTP接口、Webservice接口等类型时,接口地址可以采用URL地址,如:http://localhost:8000/XXX。
虚拟接口的调用方式可以分为get方式或post方式。采用get方式时,可以将调用时传递的数据设置在URL地址中,使用“?”符号将传递的数据和URL地址分割开。如http://localhost:8000/login.action?name=ddd&password=ooo&verify=%E4%BD%A0%E5%A5%BD。“?”符号之前的为虚拟接口的URL地址,“?”符号之后的为本次调用时传递的数据。name、password、verify为传递的多个数据的名称,彼此间使用“&”符号分割。“=”符号之后为传递的多个数据的值。传递数据时,还可以对如中文或其他非英文和数据的字符进行加密,加密算法可选用现有技术的加密算法,如将字符串用BASE64加密,得出%E4%BD%A0%E5%A5%BD。也使用cookie进行传递数据,并进行加密。虚拟接口调用方式为get方式时,虚拟接口使用get方式取得传递的数据。当然,虚拟接口也可以根据其所对应的实际程序使用get方式将数据传递给其他程序。采用post方式时,可以将需要传递的数据设置在响应体中,虚拟接口从响应体中取得传递的数据。同样,虚拟接口也可以根据其所对应的实际程序将要传递的数据设置在响应体中传递给其他程序。
虚拟接口的返回值按照虚拟接口所虚拟的实际程序的返回值类型进行设置,如实际程序的返回值为String类型,虚拟接口返回值也为Sting类型,如“aaa”。实际程序的返回值为布尔类型,虚拟接口返回值为true或false。虚拟接口返回值的类型必须与其虚拟的实际程序的返回值类型一致。当虚拟接口返回的数据采用post方式设置时,还需要配置虚拟接口的响应体。如在虚拟接口响应体中设置表单数据,调用虚拟接口的程序可以通过读取表单获得虚拟接口的返回数据。
用户可以在Web页面输入虚拟接口所需的配置信息,在获取Web页面所输入的虚拟接口的配置信息后,将配置信息存储在相应的数据库中。数据库可以对每个虚拟接口建立一条存储信息。
步骤S102,监听客户端调用虚拟接口的请求,提取调用虚拟接口的接口地址。
采用监听程序时,可以对调用虚拟接口的接口地址的端口进行监听,也可以对调用虚拟接口的接口地址进行监听。当监听到客户端调用虚拟接口的请求后,从请求中提取调用的虚拟接口的接口地址。
步骤S103,根据调用虚拟接口的接口地址,从数据库中查询虚拟接口的配置信息,返回对应的虚拟接口的返回值和/或响应体。
根据调用虚拟接口的接口地址,从数据库中查询对应调用虚拟接口的接口地址对应的虚拟接口的配置信息。根据虚拟接口所虚拟的实际程序的具体情况,相应的返回虚拟接口的返回值和/或响应体。
若虚拟接口所虚拟的实际程序需要返回返回值时,从虚拟接口的配置信息中,得到虚拟接口的返回值,返回给客户端调用程序。若虚拟接口所虚拟的实际程序需要返回响应体时,从虚拟接口的配置信息中,得到虚拟接口的响应体,返回给客户端调用程序。
进一步,若虚拟接口为API接口等类型时,虚拟接口的接口地址也可以设置为虚拟接口的接口名。虚拟接口被调用时所需的参数,也可以通过get()或set()方法进行传递。虚拟接口的返回值必须与其虚拟的实际程序的返回值类型一致。通过对以上类型的虚拟接口进行配置,输入如接口名、返回值等配置信息,并存储在数据库中。同时对客户端调用虚拟接口的请求进行监听,提取的调用虚拟接口的接口名。根据调用的虚拟接口的接口名,从数据库中查询虚拟接口的配置信息,返回对应的虚拟接口的返回值。
根据本发明所提供的基于数据库服务实时调用虚拟接口的方法,获取到通过Web页面输入的虚拟接口的配置信息后,将虚拟接口的配置信息存储在数据库中。同时对客户端调用虚拟接口的请求进行监听,根据提取的调用虚拟接口的接口地址,从数据库中查询虚拟接口的配置信息,返回对应的虚拟接口的返回值和/或响应体。通过数据库对虚拟接口的配置信息进行管理,实现快速查找和调用虚拟接口,与查找、调用代码级虚拟接口所花费的时间相比,大大减少。同时通过Web页面和数据库存储的方式所建立的虚拟接口,无需进行代码编写,降低了用户对虚拟接口代码熟悉程度的要求,使更多的用户可以简单方便的使用虚拟接口进行测试。
图2示出了根据本发明另一个实施例的基于数据库服务实时调用虚拟接口的方法的流程图。如图2所示,该方法包括以下步骤:
步骤S201,获取通过Web页面输入的虚拟接口的配置信息,将虚拟接口的配置信息存储在数据库中。
步骤S202,监听客户端调用虚拟接口的请求,提取调用虚拟接口的接口地址。
以上步骤参考图1实施例中的步骤S101和S102的描述,在此不再赘述。
步骤S203,根据调用虚拟接口的接口地址,从高速缓存中查询虚拟接口的配置信息。
高速缓存可以存储数据、信息等内容,使用高速缓存存储信息,在读取时,与数据库相比,速度更快更便捷。高速缓存还可以同时处理多个并发的查询请求,彼此间互不影响。由于高速缓存不受数据库传统存储方式的影响,不需要通过表来存储数据,也不需要对表之间建立关联关系,或发生锁表等动作,使用时,可以通过Key-Value的方式进行存储。查找时,只需针对Key值进行查找,就可以找到相应的Value。如Redis内存数据存储,使用Key-Value的方式进行存储时,还可以存储Key与5种不同类型的Value之间的映射关系。Redis能够存储数百GB的数据信息,每秒可以处理上百万次查询请求。使用Redis可以轻松应对如压力测试要求的多重并发请求。
根据调用虚拟接口的接口地址,可以先从高速缓存中查询虚拟接口的配置信息,使查找的速度更加快速。若从高速缓存中可以查询得到虚拟接口的配置信息,执行步骤S206。若从高速缓存中查询不到虚拟接口的配置信息,执行步骤S204。
步骤S204,若从高速缓存中查询不到虚拟接口的配置信息,从数据库中查询虚拟接口的配置信息。
步骤S205,将虚拟接口的配置信息写入到高速缓存中。
从数据库查找到虚拟接口的配置信息后,将虚拟接口的配置信息写入到高速缓存中,使得用户再次从高速缓存中查询该虚拟接口配置信息时,可以方便快捷的查找到,以减少使用数据库查询所花费的时间。
在将虚拟接口的配置信息写入到高速缓存时,若高速缓存空间不足时,可以按照预定规则将已写入高速缓存的虚拟接口的配置信息删除。预定规则可以为:按照高速缓存中虚拟接口的配置信息的访问时间新旧进行排序,将访问时间最旧的虚拟接口配置信息删除。或按照高速缓存中虚拟接口的配置信息的访问次数多少进行排序,将访问次数最少的虚拟接口配置信息删除。或同时按照以上两种方法进行综合排序,将访问时间最旧的、访问次数最少的虚拟接口配置信息删除。通过以上各种排序方式,将不常用的虚拟接口的配置信息删除,保留常用的虚拟接口的配置信息,以便查询使用。
步骤S206,返回对应的虚拟接口的返回值和/或响应体。
通过查询高速缓存或数据库,得到虚拟接口的配置信息后,根据虚拟接口所虚拟的实际程序的具体情况,相应的返回虚拟接口的返回值和/或响应体。
若虚拟接口所虚拟的实际程序需要返回返回值时,从虚拟接口的配置信息中,得到虚拟接口的返回值,返回给客户端调用程序。若虚拟接口所虚拟的实际程序需要返回响应体时,从虚拟接口的配置信息中,得到虚拟接口的响应体,返回给客户端调用程序。
进一步,若虚拟接口为API接口等类型时,虚拟接口的配置信息也可以存储在高速缓存中。对客户端调用虚拟接口的请求进行监听,提取的调用虚拟接口的接口名。根据调用的虚拟接口的接口名,从高速缓存中查询虚拟接口的配置信息,返回对应的虚拟接口的返回值。
根据本发明所提供的基于数据库服务实时调用虚拟接口的方法,通过高速缓存存储虚拟接口的配置信息,与数据库相比,可以更快速的查找虚拟接口,同时,高速缓存可以同时处理多次请求,极大的提高并发性的测试效果。
图3示出了根据本发明一个实施例的基于数据库服务实时调用虚拟接口装置的结构框图。如图3所示,该装置包括:存储模块301、监听模块302、数据库查询模块303、响应模块304。
存储模块301,适于获取通过Web页面输入的虚拟接口的配置信息,将虚拟接口的配置信息存储在数据库中。
存储模块301通过Web页面输入的方式,在页面中列出虚拟接口需要进行填写的配置信息,进而获取虚拟接口的配置信息。配置信息包括:虚拟接口的接口地址、调用方式、返回值和/或响应体。
虚拟接口的接口地址即虚拟了真实程序接口后的虚拟接口的调用入口,若需要的虚拟接口为HTTP接口、RPC接口、SMTP接口、Webservice接口等类型时,接口地址可以采用URL地址,如:http://localhost:8000/XXX。
虚拟接口的调用方式可以分为get方式或post方式。采用get方式时,可以将调用时传递的数据设置在URL地址中,使用“?”符号将传递的数据和URL地址分割开。如http://localhost:8000/login.action?name=ddd&password=ooo&verify=%E4%BD%A0%E5%A5%BD。“?”符号之前的为虚拟接口的URL地址,“?”符号之后的为本次调用时传递的数据。name、password、verify为传递的多个数据的名称,彼此间使用“&”符号分割。“=”符号之后为传递的多个数据的值。传递数据时,还可以对如中文或其他非英文和数据的字符进行加密,加密算法可选用现有技术的加密算法,如将字符串用BASE64加密,得出%E4%BD%A0%E5%A5%BD。也使用cookie进行传递数据,并进行加密。虚拟接口调用方式为get方式时,虚拟接口使用get方式取得传递的数据。当然,虚拟接口也可以根据其所对应的实际程序使用get方式将数据传递给其他程序。采用post方式时,可以将需要传递的数据设置在响应体中,虚拟接口从响应体中取得传递的数据。同样,虚拟接口也可以根据其所对应的实际程序将要传递的数据设置在响应体中传递给其他程序。
虚拟接口的返回值按照虚拟接口所虚拟的实际程序的返回值类型进行设置,如实际程序的返回值为String类型,虚拟接口返回值也为Sting类型,如“aaa”。实际程序的返回值为布尔类型,虚拟接口返回值为true或false。虚拟接口返回值的类型必须与其虚拟的实际程序的返回值类型一致。当虚拟接口返回的数据采用post方式设置时,还需要配置虚拟接口的响应体。如在虚拟接口响应体中设置表单数据,调用虚拟接口的程序可以通过读取表单获得虚拟接口的返回数据。
存储模块301在获取Web页面所输入的虚拟接口的配置信息后,将配置信息存储在相应的数据库中。数据库可以对每个虚拟接口建立一条存储信息。
监听模块302,适于监听客户端调用虚拟接口的请求,提取调用虚拟接口的接口地址。
监听模块302可以对调用虚拟接口的接口地址的端口进行监听,也可以对调用虚拟接口的接口地址进行监听。当监听模块302监听到客户端调用虚拟接口的请求后,从请求中提取调用的虚拟接口的接口地址。
数据库查询模块303,适于根据调用虚拟接口的接口地址,从数据库中查询虚拟接口的配置信息。
响应模块304,适于返回对应的虚拟接口的返回值和/或响应体。
数据库查询模块303根据调用虚拟接口的接口地址,从数据库中查询对应调用虚拟接口的接口地址对应的虚拟接口的配置信息。根据虚拟接口所虚拟的实际程序的具体情况,响应模块304相应的返回虚拟接口的返回值和/或响应体。
若虚拟接口所虚拟的实际程序需要返回返回值时,响应模块304将虚拟接口的返回值返回给客户端调用程序。若虚拟接口所虚拟的实际程序需要返回响应体时,响应模块304将虚拟接口的响应体返回给客户端调用程序。
进一步,若虚拟接口为API接口等类型时,虚拟接口的接口地址也可以设置为虚拟接口的接口名。虚拟接口被调用时所需的参数,也可以通过get()或set()方法进行传递。虚拟接口的返回值必须与其虚拟的实际程序的返回值类型一致。存储模块301通过Web页面对以上类型的虚拟接口进行配置,获取如接口名、返回值等配置信息,并存储在数据库中。监听模块302对客户端调用虚拟接口的请求进行监听,提取的调用虚拟接口的接口名。数据库查询模块303根据调用的虚拟接口的接口名,从数据库中查询虚拟接口的配置信息,响应模块304返回对应的虚拟接口的返回值。
根据本发明所提供的基于数据库服务实时调用虚拟接口的装置,获取到通过Web页面输入的虚拟接口的配置信息后,将虚拟接口的配置信息存储在数据库中。同时对客户端调用虚拟接口的请求进行监听,根据提取的调用虚拟接口的接口地址,从数据库中查询虚拟接口的配置信息,返回对应的虚拟接口的返回值和/或响应体。通过数据库对虚拟接口的配置信息进行管理,实现快速查找和调用虚拟接口,与查找、调用代码级虚拟接口所花费的时间相比,大大减少。同时通过Web页面和数据库存储的方式所建立的虚拟接口,无需进行代码编写,降低了用户对虚拟接口代码熟悉程度的要求,使更多的用户可以简单方便的使用虚拟接口进行测试。
图4示出了根据本发明另一个实施例的基于数据库服务实时调用虚拟接口装置的结构框图。如图4所示,该装置还包括:缓存查询模块305、缓存写入模块306和缓存删除模块307。
缓存查询模块305,适于根据调用虚拟接口的接口地址,从高速缓存中查询虚拟接口的配置信息,返回对应的虚拟接口的返回值和/或响应体。
高速缓存可以存储数据、信息等内容,使用高速缓存存储信息,在读取时,与数据库相比,速度更快更便捷。高速缓存还可以同时处理多个并发的查询请求,彼此间互不影响。由于高速缓存不受数据库传统存储方式的影响,不需要通过表来存储数据,也不需要对表之间建立关联关系,或发生锁表等动作,使用时,可以通过Key-Value的方式进行存储。查找时,只需针对Key值进行查找,就可以找到相应的Value。如Redis内存数据存储,使用Key-Value的方式进行存储时,还可以存储Key与5种不同类型的Value之间的映射关系。Redis能够存储数百GB的数据信息,每秒可以处理上百万次查询请求。使用Redis可以轻松应对如压力测试要求的多重并发请求。
缓存查询模块305根据调用虚拟接口的接口地址,可以先从高速缓存中查询虚拟接口的配置信息,使查找的速度更加快速。若缓存查询模块305从高速缓存中可以查询得到虚拟接口的配置信息,则直接返回对应的虚拟接口的返回值和/或响应体。若缓存查询模块305从高速缓存中查询不到虚拟接口的配置信息,可以由数据库查询模块303从数据库中查询虚拟接口的配置信息。
在数据库查询模块303从数据库中查询虚拟接口的配置信息后,缓存写入模块306将虚拟接口的配置信息写入到高速缓存中,使得用户再次从高速缓存中查询该虚拟接口配置信息时,可以方便快捷的查找到,以减少使用数据库查询所花费的时间。
在将虚拟接口的配置信息写入到高速缓存时,若高速缓存空间不足时,缓存删除模块307按照预定规则将已写入高速缓存的虚拟接口的配置信息删除。预定规则可以为:按照高速缓存中虚拟接口的配置信息的访问时间新旧进行排序,将访问时间最旧的虚拟接口配置信息删除。或按照高速缓存中虚拟接口的配置信息的访问次数多少进行排序,将访问次数最少的虚拟接口配置信息删除。或同时按照以上两种方法进行综合排序,将访问时间最旧的、访问次数最少的虚拟接口配置信息删除。通过以上各种排序方式,将不常用的虚拟接口的配置信息删除,保留常用的虚拟接口的配置信息,以便查询使用。
除此之外的各模块可参照图3实施例中描述,在此不再赘述。
根据本发明所提供的基于数据库服务实时调用虚拟接口的装置,通过高速缓存存储虚拟接口的配置信息,与数据库相比,可以更快速的查找虚拟接口,同时,高速缓存可以同时处理多次请求,极大的提高并发性的测试效果。
在此提供的算法和显示不与任何特定计算机、虚拟系统或者其它设备固有相关。各种通用系统也可以与基于在此的示教一起使用。根据上面的描述,构造这类系统所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多的特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
本发明的各个部件实施例可以以硬件实现,或者以在一个或者多个处理器上运行的软件模块实现,或者以它们的组合实现。本领域的技术人员应当理解,可以在实践中使用微处理器或者数字信号处理器(DSP)来实现根据本发明实施例的基于数据库服务实时调用虚拟接口装置中的一些或者全部部件的一些或者全部功能。本发明还可以实现为用于执行这里所描述的方法的一部分或者全部的设备或者装置程序(例如,计算机程序和计算机程序产品)。这样的实现本发明的程序可以存储在计算机可读介质上,或者可以具有一个或者多个信号的形式。这样的信号可以从因特网网站上下载得到,或者在载体信号上提供,或者以任何其他形式提供。
应该注意的是上述实施例对本发明进行说明而不是对本发明进行限制,并且本领域技术人员在不脱离所附权利要求的范围的情况下可设计出替换实施例。在权利要求中,不应将位于括号之间的任何参考符号构造成对权利要求的限制。单词“包含”不排除存在未列在权利要求中的元件或步骤。位于元件之前的单词“一”或“一个”不排除存在多个这样的元件。本发明可以借助于包括有若干不同元件的硬件以及借助于适当编程的计算机来实现。在列举了若干装置的单元权利要求中,这些装置中的若干个可以是通过同一个硬件项来具体体现。单词第一、第二、以及第三等的使用不表示任何顺序。可将这些单词解释为名称。
本发明还公开了:
A1、一种基于数据库服务实时调用虚拟接口的方法,其包括:
获取通过Web页面输入的虚拟接口的配置信息,将所述虚拟接口的配置信息存储在数据库中;
监听客户端调用虚拟接口的请求,提取调用虚拟接口的接口地址;
根据所述调用虚拟接口的接口地址,从数据库中查询所述虚拟接口的配置信息,返回对应的虚拟接口的返回值和/或响应体。
A2、根据A1所述的方法,其中,所述虚拟接口的配置信息包括:
虚拟接口的接口地址、调用方式、返回值和/或响应体。
A3、根据A2所述的方法,其中,所述虚拟接口的调用方式为get方式或post方式。
A4、根据A1所述的方法,其中,在所述根据调用虚拟接口的接口地址,从数据库中查询所述虚拟接口的配置信息,返回对应的虚拟接口的返回值和/或响应体之前,所述方法还包括:
根据调用虚拟接口的接口地址,从高速缓存中查询所述虚拟接口的配置信息,返回对应的虚拟接口的返回值和/或响应体。
A5、根据A4所述的方法,其中,所述从数据库中查询所述虚拟接口的配置信息进一步包括:若从所述高速缓存中查询不到所述虚拟接口的配置信息,从数据库中查询所述虚拟接口的配置信息;
所述方法还包括:将所述虚拟接口的配置信息写入到所述高速缓存中。
A6、根据A5所述的方法,其中,所述方法还包括:
若所述高速缓存空间不足时,按照预定规则将已写入高速缓存的虚拟接口的配置信息删除。
A7、根据A6所述的方法,其中,所述按照预定规则将已写入高速缓存的虚拟接口的配置信息删除进一步包括:按照高速缓存中虚拟接口的配置信息的访问时间新旧和/或访问次数多少进行排序,将访问时间最旧和/或访问次数最少的虚拟接口的配置信息删除。
B8、一种基于数据库服务实时调用虚拟接口的装置,其包括:
存储模块,适于获取通过Web页面输入的虚拟接口的配置信息,将所述虚拟接口的配置信息存储在数据库中;
监听模块,适于监听客户端调用虚拟接口的请求,提取调用虚拟接口的接口地址;
数据库查询模块,适于根据所述调用虚拟接口的接口地址,从数据库中查询所述虚拟接口的配置信息;
响应模块,适于返回对应的虚拟接口的返回值和/或响应体。
B9、根据B8所述的装置,其中,所述虚拟接口的配置信息包括:
虚拟接口的接口地址、调用方式、返回值和/或响应体。
B10、根据B9所述的装置,其中,所述虚拟接口的调用方式为get方式或post方式。
B11、根据B8所述的装置,其中,所述装置还包括:
缓存查询模块,适于根据调用虚拟接口的接口地址,从高速缓存中查询所述虚拟接口的配置信息,返回对应的虚拟接口的返回值和/或响应体。
B12、根据B11所述的装置,其中,所述数据库查询模块进一步适于:若从所述高速缓存中查询不到所述虚拟接口的配置信息,从数据库中查询所述虚拟接口的配置信息;
所述装置还包括:缓存写入模块,适于将所述虚拟接口的配置信息写入到所述高速缓存中。
B13、根据B12所述的装置,其中,所述装置还包括:
缓存删除模块,适于若所述高速缓存空间不足时,按照预定规则将已写入高速缓存的虚拟接口的配置信息删除。
B14、根据B13所述的装置,其中,所述缓存删除模块进一步适于:
按照高速缓存中虚拟接口的配置信息的访问时间新旧和/或访问次数多少进行排序,将访问时间最旧和/或访问次数最少的虚拟接口的配置信息删除。

Claims (10)

1.一种基于数据库服务实时调用虚拟接口的方法,其包括:
获取通过Web页面输入的虚拟接口的配置信息,将所述虚拟接口的配置信息存储在数据库中;
监听客户端调用虚拟接口的请求,提取调用虚拟接口的接口地址;
根据所述调用虚拟接口的接口地址,从数据库中查询所述虚拟接口的配置信息,返回对应的虚拟接口的返回值和/或响应体。
2.根据权利要求1所述的方法,其中,所述虚拟接口的配置信息包括:
虚拟接口的接口地址、调用方式、返回值和/或响应体。
3.根据权利要求2所述的方法,其中,所述虚拟接口的调用方式为get方式或post方式。
4.根据权利要求1所述的方法,其中,在所述根据调用虚拟接口的接口地址,从数据库中查询所述虚拟接口的配置信息,返回对应的虚拟接口的返回值和/或响应体之前,所述方法还包括:
根据调用虚拟接口的接口地址,从高速缓存中查询所述虚拟接口的配置信息,返回对应的虚拟接口的返回值和/或响应体。
5.根据权利要求4所述的方法,其中,所述从数据库中查询所述虚拟接口的配置信息进一步包括:若从所述高速缓存中查询不到所述虚拟接口的配置信息,从数据库中查询所述虚拟接口的配置信息;
所述方法还包括:将所述虚拟接口的配置信息写入到所述高速缓存中。
6.根据权利要求5所述的方法,其中,所述方法还包括:
若所述高速缓存空间不足时,按照预定规则将已写入高速缓存的虚拟接口的配置信息删除。
7.根据权利要求6所述的方法,其中,所述按照预定规则将已写入高速缓存的虚拟接口的配置信息删除进一步包括:按照高速缓存中虚拟接口的配置信息的访问时间新旧和/或访问次数多少进行排序,将访问时间最旧和/或访问次数最少的虚拟接口的配置信息删除。
8.一种基于数据库服务实时调用虚拟接口的装置,其包括:
存储模块,适于获取通过Web页面输入的虚拟接口的配置信息,将所述虚拟接口的配置信息存储在数据库中;
监听模块,适于监听客户端调用虚拟接口的请求,提取调用虚拟接口的接口地址;
数据库查询模块,适于根据所述调用虚拟接口的接口地址,从数据库中查询所述虚拟接口的配置信息;
响应模块,适于返回对应的虚拟接口的返回值和/或响应体。
9.根据权利要求8所述的装置,其中,所述虚拟接口的配置信息包括:
虚拟接口的接口地址、调用方式、返回值和/或响应体。
10.根据权利要求9所述的装置,其中,所述虚拟接口的调用方式为get方式或post方式。
CN201610519713.8A 2016-07-04 2016-07-04 基于数据库服务实时调用虚拟接口的方法及装置 Active CN107577590B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201610519713.8A CN107577590B (zh) 2016-07-04 2016-07-04 基于数据库服务实时调用虚拟接口的方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201610519713.8A CN107577590B (zh) 2016-07-04 2016-07-04 基于数据库服务实时调用虚拟接口的方法及装置

Publications (2)

Publication Number Publication Date
CN107577590A true CN107577590A (zh) 2018-01-12
CN107577590B CN107577590B (zh) 2023-12-05

Family

ID=61049260

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201610519713.8A Active CN107577590B (zh) 2016-07-04 2016-07-04 基于数据库服务实时调用虚拟接口的方法及装置

Country Status (1)

Country Link
CN (1) CN107577590B (zh)

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN108319504A (zh) * 2018-03-19 2018-07-24 武汉斗鱼网络科技有限公司 内存占用优化方法、装置及可读存储介质
CN109117290A (zh) * 2018-08-20 2019-01-01 郑州云海信息技术有限公司 一种接口的模拟方法和装置
CN109460266A (zh) * 2018-10-29 2019-03-12 无锡华云数据技术服务有限公司 一种构造软件模拟数据的方法及装置
CN110287039A (zh) * 2019-06-26 2019-09-27 网易无尾熊(杭州)科技有限公司 模拟接口配置方法、介质、装置和计算设备
CN111752625A (zh) * 2020-06-23 2020-10-09 京东数字科技控股有限公司 用于接口mock的方法和装置
CN112131118A (zh) * 2020-09-25 2020-12-25 平安国际智慧城市科技股份有限公司 Mock测试方法、装置、电子设备及计算机可读存储介质

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101187937A (zh) * 2007-10-30 2008-05-28 北京航空航天大学 网格环境下模式复用的异构数据库访问和集成方法
CN101577647A (zh) * 2009-06-15 2009-11-11 中兴通讯股份有限公司 一种支持多vlan的告警箱及其告警处理方法
CN104639539A (zh) * 2015-01-27 2015-05-20 深圳市汇朗科技有限公司 接口调用的方法和装置
CN105490826A (zh) * 2014-09-16 2016-04-13 钛马信息网络技术有限公司 基于自动发现的配置管理系统及方法
US20160125052A1 (en) * 2013-11-29 2016-05-05 Ca, Inc. Database virtualization

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101187937A (zh) * 2007-10-30 2008-05-28 北京航空航天大学 网格环境下模式复用的异构数据库访问和集成方法
CN101577647A (zh) * 2009-06-15 2009-11-11 中兴通讯股份有限公司 一种支持多vlan的告警箱及其告警处理方法
US20160125052A1 (en) * 2013-11-29 2016-05-05 Ca, Inc. Database virtualization
CN105490826A (zh) * 2014-09-16 2016-04-13 钛马信息网络技术有限公司 基于自动发现的配置管理系统及方法
CN104639539A (zh) * 2015-01-27 2015-05-20 深圳市汇朗科技有限公司 接口调用的方法和装置

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN108319504A (zh) * 2018-03-19 2018-07-24 武汉斗鱼网络科技有限公司 内存占用优化方法、装置及可读存储介质
CN108319504B (zh) * 2018-03-19 2021-01-01 武汉斗鱼网络科技有限公司 内存占用优化方法、装置及可读存储介质
CN109117290A (zh) * 2018-08-20 2019-01-01 郑州云海信息技术有限公司 一种接口的模拟方法和装置
CN109117290B (zh) * 2018-08-20 2021-10-01 郑州云海信息技术有限公司 一种接口的模拟方法和装置
CN109460266A (zh) * 2018-10-29 2019-03-12 无锡华云数据技术服务有限公司 一种构造软件模拟数据的方法及装置
CN110287039A (zh) * 2019-06-26 2019-09-27 网易无尾熊(杭州)科技有限公司 模拟接口配置方法、介质、装置和计算设备
CN111752625A (zh) * 2020-06-23 2020-10-09 京东数字科技控股有限公司 用于接口mock的方法和装置
CN112131118A (zh) * 2020-09-25 2020-12-25 平安国际智慧城市科技股份有限公司 Mock测试方法、装置、电子设备及计算机可读存储介质

Also Published As

Publication number Publication date
CN107577590B (zh) 2023-12-05

Similar Documents

Publication Publication Date Title
CN107577590A (zh) 基于数据库服务实时调用虚拟接口的方法及装置
US20190057107A1 (en) Access control for unprotected data storage system endpoints
KR20140014132A (ko) 컨텐츠 제공자-특이 url 키워드 검색 제공을 위한 방법 및 시스템
CN104468790B (zh) cookie数据的处理方法与客户端
CN109783543B (zh) 数据查询方法、装置、设备和存储介质
CN104901943A (zh) 一种访问网站的方法和系统
US10943063B1 (en) Apparatus and method to automate website user interface navigation
CN110704476A (zh) 数据处理方法、装置、设备及存储介质
CN107861981A (zh) 一种数据处理方法及装置
US11216482B2 (en) Systems and methods for access to multi-tenant heterogeneous databases
CN108173839A (zh) 权限管理方法及系统
CN109450969A (zh) 从第三方数据源服务器中获取数据的方法、装置和服务器
CN103366011B (zh) 通过浏览器地址栏访问认证网址的方法、及装置
EP2711852A1 (en) Methods and systems for providing content provider-specified URL keyword navigation
CN109992500A (zh) 应用的接口测试方法、装置和计算机可读存储介质
CN110929185A (zh) 网站目录检测方法、装置、计算机设备及计算机存储介质
US11442995B2 (en) Filtering of log search results based on automated analysis
CN108664811A (zh) 一种权限管理方法及装置
US9398041B2 (en) Identifying stored vulnerabilities in a web service
CN105404827B (zh) 控制应用程序之间通信的方法、装置及系统
CN112037865A (zh) 物种科学名称确定方法、装置、电子设备及存储介质
US9449036B2 (en) Handling an increase in transactional data without requiring relocation of preexisting data between shards
US20220229858A1 (en) Multi-cloud object store access
CN105893462A (zh) 一种用户网络行为分析方法及装置
CN105069108B (zh) 基于PaaS系统大数据查询方法及装置

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
CP03 Change of name, title or address

Address after: 100088 room 112, block D, 28 new street, new street, Xicheng District, Beijing (Desheng Park)

Patentee after: BEIJING QIHOO TECHNOLOGY Co.,Ltd.

Country or region after: China

Patentee after: Beijing Qizhi Business Consulting Co.,Ltd.

Address before: 100088 room 112, block D, 28 new street, new street, Xicheng District, Beijing (Desheng Park)

Patentee before: BEIJING QIHOO TECHNOLOGY Co.,Ltd.

Country or region before: China

Patentee before: Qizhi software (Beijing) Co.,Ltd.

CP03 Change of name, title or address
TR01 Transfer of patent right

Effective date of registration: 20240122

Address after: 100088 room 112, block D, 28 new street, new street, Xicheng District, Beijing (Desheng Park)

Patentee after: BEIJING QIHOO TECHNOLOGY Co.,Ltd.

Country or region after: China

Address before: 100088 room 112, block D, 28 new street, new street, Xicheng District, Beijing (Desheng Park)

Patentee before: BEIJING QIHOO TECHNOLOGY Co.,Ltd.

Country or region before: China

Patentee before: Beijing Qizhi Business Consulting Co.,Ltd.

TR01 Transfer of patent right