CN115348246A - 多用户在线代理抓包调试的方法、设备、系统及介质 - Google Patents
多用户在线代理抓包调试的方法、设备、系统及介质 Download PDFInfo
- Publication number
- CN115348246A CN115348246A CN202210806782.2A CN202210806782A CN115348246A CN 115348246 A CN115348246 A CN 115348246A CN 202210806782 A CN202210806782 A CN 202210806782A CN 115348246 A CN115348246 A CN 115348246A
- Authority
- CN
- China
- Prior art keywords
- file
- service request
- request information
- client
- 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
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/02—Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L43/00—Arrangements for monitoring or testing data switching networks
- H04L43/12—Network monitoring probes
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Debugging And Monitoring (AREA)
Abstract
本发明公开了一种多用户在线代理抓包调试的方法,包括步骤:客户端向抓包管理系统发送服务请求信息;所述抓包管理系统的调试代理工具Whistle依据所述客户端的配置规则,将所述服务请求信息转发至目标服务器;所述目标服务器的本地文件模拟工具依据所述服务请求信息的统一资源定位符URL按照设定规则转化的文件名,并解析所述文件名对应的文件内容,或将用户服务请求信息发送至远程网络服务器;所述抓包管理系统的调试代理工具Whistle获取所述远程网络服务器的响应内容,并将响应内容发送给客户端,将用户服务请求信息和响应内容信息发布到消息队列RabbitMQ中。本申请可以使多个用户同时在线使用代理服务,方便做服务扩展,能够实现多用户之间的数据或配置共享。
Description
技术领域
本发明涉及数据处理技术领域,尤其是一种多用户在线代理抓包调试的方法、电子设备、系统及存储介质。
背景技术
在现有技术中,代理工具在多用户开发中经常被使用,主要用于抓包调试、接口转换、程序代理等,特别是在开发移动端网络程序时,代理工具会被更加频繁使用,代理工具一般会把请求方的网络流量转发给目标服务器,如果在根证书颁发机构信任了代理工具生成的证书,使用代理工具可以解析HTTPS流量,代理工具在转发流量的同时可以修改请求信息,以及修改响应信息。现有技术存在如下方案,一是在本地安装抓包工具,这种方式易于安装,开箱即用,原生UI开发的界面,在体验上更好,但是只能使用本地网络代理转发流量,而且基于原生UI的方式难于跨平台和远程共享使用,必须在本地电脑上查看分析网络流量;二是采用基于NodeJS+浏览器远程访问流量,该方法更方便的跨平台支持,更丰富的扩展支持,用户可以将代理工具部署在专门的机器上,但是该方案无法同时部署多个代理服务,供多人使用,当部署在其他机器上时会有功能缺失。
因此,需要一种能够多用户在线代理抓包调试的方法,提升不同代理服务的多用户使用,并能够共享文件,分析流量。
发明内容
为此,本发明提供了一种多用户在线代理抓包调试的方法、电子设备、系统及存储介质,以力图解决或者至少缓解上面存在的至少一个问题。
根据本发明的一个方面,提供了一种多用户在线代理抓包调试的方法,该方法通过抓包管理系统将多个客户端的请求传递给目标服务器,并根据目标服务器的处理规则响应客户端的请求,实现多用户在线代理抓包调试,所述方法包括步骤:
所述客户端向抓包管理系统发送服务请求信息,所述抓包管理系统包括代理端口、代理服务器、进程管理工具PM2、调试代理工具Whistle;
依据所述客户端向抓包管理系统发送的服务请求信息,所述抓包管理系统的调试代理工具Whistle依据所述客户端的配置规则,将所述服务请求信息转发至目标服务器,所述目标服务器包括远程网络服务器、中间件Middleware、本地文件模拟工具;
依据所述抓包管理系统的调试代理工具Whistle将所述服务请求信息转发至目标服务器,所述目标服务器的本地文件模拟工具依据所述服务请求信息的统一资源定位符URL按照设定规则转化的文件名,并解析所述文件名对应的文件内容,或将用户服务请求信息发送至远程网络服务器;
依据所述目标服务器的本地文件模拟工具依据所述服务请求信息的统一资源定位符URL按照设定规则转化的文件名,并解析所述文件名对应的文件内容,或将用户服务请求信息发送至远程网络服务器,所述抓包管理系统的调试代理工具Whistle获取所述远程网络服务器的响应内容,并将响应内容发送给客户端,将用户服务请求信息和响应内容信息发布到消息队列RabbitMQ中。
可选的,所述客户端向抓包管理系统发送服务请求信息的步骤包括:
客户端通过用户登录账号登录抓包管理系统;
依据所述客户端通过用户登录账号登录抓包管理系统,客户端选择抓包管理系统的一个代理端口,并连接所述代理端口指向的代理服务器;
客户端生成服务请求信息,并向所述代理端口发送HTTP请求,将所述服务请求信息通过代理端口发送至指向的代理服务器。
可选的,所述抓包管理系统的调试代理工具Whistle依据所述客户端的配置规则,将所述服务请求信息转发至目标服务器的步骤包括:
所述抓包管理系统的代理服务器将所述客户端的服务请求信息转发至所述抓包管理系统的进程管理工具PM2;
所述抓包管理系统的进程管理工具PM2将所述服务请求信息转发至所述抓包管理系统的调试代理工具Whistle;
所述抓包管理系统的调试代理工具Whistle根据所述客户端的配置规则,将所述服务请求信息转发至目标服务器。
可选的,所述目标服务器的本地文件模拟工具依据所述服务请求信息的统一资源定位符URL按照设定规则转化的文件名,并解析所述文件名对应的文件内容,或将用户服务请求信息发送至远程网络服务器的步骤包括:
所述本地文件模拟工具获取所述抓包管理系统的调试代理工具Whistle转发的客户端服务请求信息;
依据所述客户端的服务请求信息,所述本地文件模拟工具获取所述服务请求信息所对应的统一资源定位符URL;
依据所述服务请求信息所对应的统一资源定位符URL,所述本地文件模拟工具按照设定的规则将根据所述服务请求信息所对应的统一资源定位符URL转换为文件名;
依据所述统一资源定位符URL转换的文件名,所述本地文件模拟工具查找所述文件名对应的文件;
如果查找到对应的文件,所述本地文件模拟工具解析所述文件内容,并执行所述文件内容的代码;
如果查找不到所述统一资源定位符URL转换的文件名对应的文件,所述目标服务器将所述客户端的服务请求信息转发至远程网络服务器。
可选的,所述本地文件模拟工具按照设定的规则将根据所述服务请求信息所对应的统一资源定位符URL转换为文件名的步骤包括:
依据所述服务请求信息所对应的统一资源定位符URL,所述本地文件模拟工具获取所述统一资源定位符URL的最后一段路径,以及所述统一资源定位符URL的某一个参数值;
依据所述本地文件模拟工具获取所述统一资源定位符URL的最后一段路径,以及所述统一资源定位符URL的某一个参数值,获取所述统一资源定位符URL的最后一段路径,及所述统一资源定位符URL的某一个参数值的配配置;
依据所述统一资源定位符URL的最后一段路径,及所述统一资源定位符URL的某一个参数值的配配置,递归指定文件目录下的所有文件;
依据所述递归指定文件目录下的所有文件,获取所述统一资源定位符URL转换的文件名。
可选的,所述本地文件模拟工具查找所述文件名对应的文件,解析所述文件内容,并执行所述文件内容的代码的步骤包括:
本地文件模拟工具查找所述文件名所匹配的文件,所述文件名包括文件扩展名;
如果查找到匹配文件,则获取所述文件内容,并解析所述文件内容头部定义的元数据;
如果查找不到匹配文件,则本地文件模拟工具查找所述文件名不包括扩展名时所匹配的文件;
如果查找到匹配文件,则获取所述文件内容,并解析所述文件内容头部定义的元数据;
所述本地文件模拟工具判断所述文件内容头部定义的元数据中开关状态MEATstatus指令的状态是否为关闭;
如果未关闭,则所述本地文件模拟工具判断所述文件内容头部定义的元数据中解析类型MEAT openType指令是否有效;
如果有效,则并行执行所述文件内容头部定义的元数据中raw-comments-json指令、require-promise指令、require-raw指令、require-function指令,并返回相应执行结果;
所述本地文件模拟工具判断所述文件内容头部定义的元数据中MEAT wait指令是否为有效数字;
如果是有效数字,则执行所述MEAT wait指令的延迟事件后返回执行结果;
所述本地文件模拟工具将所述文件内容的代码执行结果返回至所述抓包管理系统的调试代理工具Whistle;
如果所述本地文件模拟工具查找不到所述文件名对应的文件,则所述目标服务器将所述客户端的服务请求信息转发至远程网络服务器。
可选的,所述将用户服务请求信息和响应内容信息发布到消息队列RabbitMQ中包括:
依据所述消息队列RabbitMQ中响应内容信息数量,获取所述客户端的连接数量。
根据本发明的又一方面,提供了一种计算设备,包括:一个或多个处理器;和存储器;一个或多个程序,其中所述一个或多个程序存储在存储器中并被配置为由一个或多个处理器执行,所述一个或多个程序包括用于执行如上所述多用户在线代理抓包调试的方法中的任一方法的指令。
根据本发明的又一方面,提供了一种多用户在线代理转包调试系统,其特征在于,所述系统包括电子设备,所述电子设备用于执行如上所述多用户在线代理抓包调试的方法中的任一方法的指令。
根据本发明的又一方面,提供了一种存储一个或多个程序的计算机可读存储介质,所述一个或多个程序包括指令,所述指令当计算设备执行时,使得计算设备执行如上所述多用户在线代理抓包调试的方法中的任一方法。
根据本发明的多用户在线代理抓包调试的方案,通过所述客户端向抓包管理系统发送服务请求信息;所述抓包管理系统的调试代理工具Whistle依据所述客户端的配置规则,将所述服务请求信息转发至目标服务器;所述目标服务器的本地文件模拟工具依据所述服务请求信息的统一资源定位符URL按照设定规则转化的文件名,并解析所述文件名对应的文件内容,或将用户服务请求信息发送至远程网络服务器;所述抓包管理系统的调试代理工具Whistle获取所述远程网络服务器的响应内容,并将响应内容发送给客户端,将用户服务请求信息和响应内容信息发布到消息队列RabbitMQ中。本申请可以使多个用户同时在线使用代理服务,方便做服务扩展,能够实现多用户之间的数据或配置共享。
附图说明
为了实现上述以及相关目的,本文结合下面的描述和附图来描述某些说明性方面,这些方面指示了可以实践本文所公开的原理的各种方式,并且所有方面及其等效方面旨在落入所要求保护的主题的范围内。通过结合附图阅读下面的详细描述,本公开的上述以及其它目的、特征和优势将变得更加明显。遍及本公开,相同的附图标记通常指代相同的部件或元素。
图1示出了根据本发明一个实施例的应用场景示意图;以及
图2示出了根据本发明一个实施例的计算设备100的构造示意图;以及
图3示出了根据本发明一个实施例的多用户在线代理抓包调试的方法200应用的架构图;
图4示出了根据本发明一个实施例的多用户在线代理抓包调试的方法200的流程图;以及
图5示出了根据本发明另一个实施例的多用户在线代理抓包调试的方法的流程图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
图1是本发明一个实施例的应用场景示意图,本申请提供的多用户在线代理抓包调试的方法,可以应用于如图1所示的应用环境中。该多用户在线代理抓包调试的方法应用于多用户在线代理抓包调试系统中。该多用户在线代理抓包调试系统配置在服务器010中,或者部分配置在终端020,部分配置在服务器010中,由终端020与服务器010交互完成多用户在线代理抓包调试的方法。
其中,终端020与服务器010可以通过网络进行通信。
其中,终端020可以但不限于是各种个人计算机、笔记本电脑、智能手机、平板电脑和便携式可穿戴设备,本申请的服务器010可以用独立的服务器或者是多个服务器组成的服务器集群来实现。
图2是示例计算设备100的框图。在基本的配置102中,计算设备100典型地包括系统存储器106和一个或者多个处理器104。存储器总线108可以用于在处理器104和系统存储器106之间的通信。
取决于期望的配置,处理器104可以是任何类型的处理,包括但不限于:微处理器(μP)、微控制器(μC)、数字信息处理器(DSP)或者它们的任何组合。处理器104可以包括诸如一级高速缓存110和二级高速缓存112之类的一个或者多个级别的高速缓存、处理器核心114和寄存器116。示例的处理器核心114可以包括运算逻辑单元(ALU)、浮点数单元(FPU)、数字信号处理核心(DSP核心)或者它们的任何组合。示例的存储器控制器118可以与处理器104一起使用,或者在一些实现中,存储器控制器118可以是处理器104的一个内部部分。
取决于期望的配置,系统存储器106可以是任意类型的存储器,包括但不限于:易失性存储器(诸如RAM)、非易失性存储器(诸如ROM、闪存等)或者它们的任何组合。系统存储器106可以包括操作系统120、一个或者多个应用122以及程序数据124。在一些实施方式中,应用122可以布置为在操作系统上利用程序数据124进行操作。在一些实施例中,计算设备100被配置为执行多用户在线代理抓包调试的方法200,该方法200通过抓包管理系统将多个客户端的请求传递给目标服务器,并根据目标服务器的处理规则响应客户端的请求,实现多用户在线代理抓包调试,程序数据124中包含了用于执行该方法200的指令。
计算设备100还可以包括有助于从各种接口设备(例如,输出设备142、外设接口144和通信设备146)到基本配置102经由总线/接口控制器130的通信的接口总线140。示例的输出设备142包括图形处理单元148和音频处理单元150。它们可以被配置为有助于经由一个或者多个A/V端口152与诸如显示器或者扬声器之类的各种外部设备进行通信。示例外设接口144可以包括串行接口控制器154和并行接口控制器156,它们可以被配置为有助于经由一个或者多个I/O端口158和诸如输入设备(例如,键盘、鼠标、笔、语音输入设备、触摸输入设备)或者其他外设(例如打印机、扫描仪等)之类的外部设备进行通信。示例的通信设备146可以包括网络控制器160,其可以被布置为便于经由一个或者多个通信端口164与一个或者多个其他计算设备162通过网络通信链路的通信。
网络通信链路可以是通信介质的一个示例。通信介质通常可以体现为在诸如载波或者其他传输机制之类的调制数据信号中的计算机可读指令、数据结构、程序模块,并且可以包括任何信息递送介质。“调制数据信号”可以这样的信号,它的数据集中的一个或者多个或者它的改变可以在信号中编码信息的方式进行。作为非限制性的示例,通信介质可以包括诸如有线网络或者专线网络之类的有线介质,以及诸如声音、射频(RF)、微波、红外(IR)或者其它无线介质在内的各种无线介质。这里使用的术语计算机可读介质可以包括存储介质和通信介质二者。在一些实施例中,计算机可读介质中存储一个或多个程序,这一个或多个程序中包括执行某些方法的指令,如根据本发明的实施例,计算设备100通过所述指令来执行多用户在线代理抓包调试的方法200。
计算设备100可以实现为小尺寸便携(或者移动)电子设备的一部分,这些电子设备可以是诸如蜂窝电话、个人数字助理(PDA)、个人媒体播放器设备、无线网络浏览设备、个人头戴设备、应用专用设备、或者可以包括上面任何功能的混合设备。计算设备100还可以实现为包括桌面计算机和笔记本计算机配置的个人计算机。
图3示出了根据本发明一个实施例的多用户在线代理抓包调试的方法200应用的架构图。如图3所示,该架构包括客户端、抓包管理系统和目标服务器,所述客户端通过抓包管理系统将多个客户端的请求传递给目标服务器,并根据目标服务器的处理规则响应客户端的请求,实现多用户在线代理抓包调试。
其中,所述抓包管理系统包括:代理端口、代理服务器、进程管理工具PM2、调试代理工具Whistle,所述代理端口与所述客户端连接,并指向指定的代理服务器,客户端的服务请求信息通过指定的代理端口发送到代理端口指向的服务器,并由服务器将服务请求信息发送给进程管理工具PM2,由进程管理工具PM2按照进程次序将多个客户端的服务请求信息发送给调试代理工具Whistle,调试代理工具Whistle根据用户配置的规则决定是否将客户端的服务请求信息发送给目标服务器。
目标服务器包括:远程网络服务器、中间件Middleware、本地文件模拟工具,其中目标服务器的本地文件模拟工具接收到调试代理工具Whistle发送的服务请求信息,并根据服务请求信息的统一资源定位符URL按照设定规则转换为文件名,并查找所述文件名所匹配的文件,对文件内容进行解析并执行文件代码,在执行完毕后将结果返回给调试代理工具Whistle,如果本地文件模拟工具没有查找到所述文件名所匹配的文件,则将客户端的服务请求信息发送至远程网络服务器,调试代理工具Whistle将接收的本地文件模拟工具解析文件后的返回结果转发给客户端,并同时将客户端的服务请求信息和本地文件模拟工具的响应信息发布到消息队列RabbitMQ中。
图4示出了根据本发明一个实施例的多用户在线代理抓包调试的方法200的流程图,如图4所示,该方法200方法通过抓包管理系统将多个客户端的请求传递给目标服务器,并根据目标服务器的处理规则响应客户端的请求,实现多用户在线代理抓包调试,方法200始于步骤S210,所述客户端向抓包管理系统发送服务请求信息,所述抓包管理系统包括代理端口、代理服务器、进程管理工具PM2、调试代理工具Whistle。
具体的,抓包管理系统在本申请的实施例中作为一种代理工具,客户端通过抓包管理系统实现对远程服务器的访问,同时实现多个用户同时使用代理,使多用户实现资源共享,在本实施例的抓包管理系统不同于本地安装的Fiddler、Charles和Whistle这些软件,本申请实施例的抓包管理系统对用户来说是完全免费的,只需要用户的客户端登录抓包管理系统的管理后台,选择一个端口号即可进行登录,然后在浏览器或者客户端设置一下代理即可。
具体的,抓包管理系统中的代理端口用于提供客户端连接的端口;
代理服务器用于接收代理端口转发的客户端的服务请求信息,并将服务请求信息转发到进程管理工具PM2;
进程管理工具PM2,用于伺服NodeJS程序,进程管理工具PM2是一个进程管理工具,可以用它来管理你的node进程,并查看node进程的状态,当然也支持性能监控,进程守护,负载均衡等功能,在本申请的实施例中,进程管理工具PM2用于按照设定的规则将多个代理服务器发送的每一个客户端的服务请求信息加入列表,并按照列表顺序将客户端的服务请求信息发送给调试代理工具Whistle;
调试代理工具Whistle为基于Node实现的跨平台web调试代理工具,用于按照设定的规则调试服务请求信息,并转发至相应的目标服务器。
具体的,在本申请的一个实施例中,所述客户端向抓包管理系统发送服务请求信息的步骤包括:
客户端通过用户登录账号登录抓包管理系统;
依据所述客户端通过用户登录账号登录抓包管理系统,客户端选择抓包管理系统的一个代理端口,并连接所述代理端口指向的代理服务器;
客户端生成服务请求信息,并向所述代理端口发送HTTP请求,将所述服务请求信息通过代理端口发送至指向的代理服务器。
具体的,比如以手机用户为例,用户使用OA账号登录抓包管理系统,选择一个端口号为3000的代理端口,在设置收集的代理服务器后,打开浏览器或者客户端APP,发起HTTP连接请求,HTTP请求会首先到达代理服务器的代理端口3000,然后通过代理端口3000将服务请求信息发送到指向的代理服务器。
具体的,本申请的抓包管理系统通过代理端口、代理服务器、进程管理工具PM2、调试代理工具Whistle的技术方案,为多个客户端提供了一个代理管理平台,可以同时管理多个代理服务,让多个用户同时在线使用代理,并共享团队资源,服务请求信息的响应信息从调试代理工具Whistle返还给客户端时,会同时将网络请求转发到RabbitMQ消息队列,方便做一些扩展,这些扩展可以是增加一个消费程序,监听消息队列,保存网络请求,用于后续分析。
通过步骤S220,依据所述客户端向抓包管理系统发送的服务请求信息,所述抓包管理系统的调试代理工具Whistle依据所述客户端的配置规则,将所述服务请求信息转发至目标服务器,所述目标服务器包括远程网络服务器、中间件Middleware、本地文件模拟工具。
具体的,在抓包管理系统接收到客户端的服务请求信息之后,抓包管理系统的调试代理工具Whistle依据所述客户端的配置规则,将所述服务请求信息转发至目标服务器。
具体的,所述目标服务器的远程网络服务器用于对客户端的服务请求信息提供远程网络服务支持;
中间件Middleware是为应用提供通用服务和功能的软件;
本地文件模拟工具为Local File Mock,mock是在测试过程中,对于一些不容易构造或获取的对象,创建一个mock对象来模拟对象的行为,而这个虚拟的对象就是mock对象。mock对象就是真实对象在调试期间的代替品。在本申请的实施例中,本地文件模拟工具用于根据客户端的服务请求信息的统一资源定位符URL按照设定规则转化的文件名,并解析所述文件名对应的文件内容,或将用户服务请求信息发送至远程网络服务器。
具体的,在本申请的一个实施例中,所述抓包管理系统的调试代理工具Whistle依据所述客户端的配置规则,将所述服务请求信息转发至目标服务器的步骤包括:
所述抓包管理系统的代理服务器将所述客户端的服务请求信息转发至所述抓包管理系统的进程管理工具PM2;
所述抓包管理系统的进程管理工具PM2将所述服务请求信息转发至所述抓包管理系统的调试代理工具Whistle;
所述抓包管理系统的调试代理工具Whistle根据所述客户端的配置规则,将所述服务请求信息转发至目标服务器。
通过步骤S230,依据所述抓包管理系统的调试代理工具Whistle将所述服务请求信息转发至目标服务器,所述目标服务器的本地文件模拟工具依据所述服务请求信息的统一资源定位符URL按照设定规则转化的文件名,并解析所述文件名对应的文件内容,或将用户服务请求信息发送至远程网络服务器。
具体的,本地文件模拟工具根据所述服务请求信息的统一资源定位符URL按照设定规则转化的文件名,并在文件库中查找与转化的文件名所匹配的文件,然后对文件内容进行解析,并使用Node环境执行文件内容中的代码,并返还给调试代理工具Whistle,如果本地文件模拟工具没有找到匹配的文件,就将客户端的服务请求信息通过NEXT程序传递给客户端实际请求的远程网络服务器。
具体的,在本申请的一个实施例中,所述目标服务器的本地文件模拟工具依据所述服务请求信息的统一资源定位符URL按照设定规则转化的文件名,并解析所述文件名对应的文件内容,或将用户服务请求信息发送至远程网络服务器的步骤包括:
所述本地文件模拟工具获取所述抓包管理系统的调试代理工具Whistle转发的客户端服务请求信息;
依据所述客户端的服务请求信息,所述本地文件模拟工具获取所述服务请求信息所对应的统一资源定位符URL;具体的,所述服务请求信息所对应的统一资源定位符URL是客户端所发送的服务请求信息所指向的远程网络服务器的统一资源定位符URL信息,用于将客户端的服务请求信息发送到目标的远程网络服务器。
依据所述服务请求信息所对应的统一资源定位符URL,所述本地文件模拟工具按照设定的规则将根据所述服务请求信息所对应的统一资源定位符URL转换为文件名;
依据所述统一资源定位符URL转换的文件名,所述本地文件模拟工具查找所述文件名对应的文件;
如果查找到对应的文件,所述本地文件模拟工具解析所述文件内容,并执行所述文件内容的代码;
如果查找不到所述统一资源定位符URL转换的文件名对应的文件,所述目标服务器将所述客户端的服务请求信息转发至远程网络服务器。
具体的,通过本地文件模拟工具来查找统一资源定位符URL转换的文件名,可以查看在本地是否存在统一资源定位符URL所存在的远程网络服务器文件,如果存在,说明可以通过本地文件模拟工具就可以实现客户端的服务请求信息所请求的服务,这时就不需要再通过远程网络服务去提供相应的服务,如果本地文件模拟工具没有查找到匹配的文件,此时,只能继续通过远程网络服务器去提供网络服务。
具体的,如图5所示,在本申请的一个实施例中,所述本地文件模拟工具按照设定的规则将根据所述服务请求信息所对应的统一资源定位符URL转换为文件名的步骤包括:
依据所述服务请求信息所对应的统一资源定位符URL,所述本地文件模拟工具获取所述统一资源定位符URL的最后一段路径,以及所述统一资源定位符URL的某一个参数值;
依据所述本地文件模拟工具获取所述统一资源定位符URL的最后一段路径,以及所述统一资源定位符URL的某一个参数值,获取所述统一资源定位符URL的最后一段路径,及所述统一资源定位符URL的某一个参数值的配配置;
依据所述统一资源定位符URL的最后一段路径,及所述统一资源定位符URL的某一个参数值的配配置,递归指定文件目录下的所有文件;
依据所述递归指定文件目录下的所有文件,获取所述统一资源定位符URL转换的文件名。
具体的,如图5所示,在本申请的一个实施例中,所述本地文件模拟工具查找所述文件名对应的文件,解析所述文件内容,并执行所述文件内容的代码的步骤包括:
本地文件模拟工具查找所述文件名所匹配的文件,所述文件名包括文件扩展名;
如果查找到匹配文件,则获取所述文件内容,并解析所述文件内容头部定义的元数据;
如果查找不到匹配文件,则本地文件模拟工具查找所述文件名不包括扩展名时所匹配的文件;
如果查找到匹配文件,则获取所述文件内容,并解析所述文件内容头部定义的元数据;
所述本地文件模拟工具判断所述文件内容头部定义的元数据中开关状态MEATstatus指令的状态是否为关闭;
如果未关闭,则所述本地文件模拟工具判断所述文件内容头部定义的元数据中解析类型MEAT openType指令是否有效;
如果有效,则并行执行所述文件内容头部定义的元数据中raw-comments-json指令、require-promise指令、require-raw指令、require-function指令,并返回相应执行结果;
所述本地文件模拟工具判断所述文件内容头部定义的元数据中MEAT wait指令是否为有效数字;
如果是有效数字,则执行所述MEAT wait指令的延迟事件后返回执行结果;
所述本地文件模拟工具将所述文件内容的代码执行结果返回至所述抓包管理系统的调试代理工具Whistle;
如果所述本地文件模拟工具查找不到所述文件名对应的文件,则所述目标服务器将所述客户端的服务请求信息转发至远程网络服务器。
具体的,本申请将调试代理工具Whistle的代理服务统一部署到一个远程网络服务器上,通过代理抓包系统控制每个代理服务,可以做到团队的Mock文件等数据或配置共享。不同于平常的静态Mock文件,本申请的每个Mock文件都是一个迷你的Express中间件代码,同时提供了简单的DSL(domain-specific language,领域特定语言)指令,方便控制中间件的开启关闭状态(META.status)、响应类型(META.contentType)及中间件解析类型(META.openType)。这个Mock文件会作为一个Node模块在Node环境中执行,执行的时候会注入一些全局依赖,最终会动态返回Mock数据。
本申请除了提供强大的Mock文件规范和解析执行功能外,为了解决无法便捷远程编辑修改Mock文件的问题,同时提供了Web IDE,可以通过浏览器编辑Mock文件,并实时生效,本方案还会把调试代理工具Whistle中的网络请求转发到RabbitMQ消息队列中,方便做一些扩展,比如可以增加一个消费程序,监听消息队列,保存网络请求,用于后续分析。
通过步骤S240,依据所述目标服务器的本地文件模拟工具依据所述服务请求信息的统一资源定位符URL按照设定规则转化的文件名,并解析所述文件名对应的文件内容,或将用户服务请求信息发送至远程网络服务器,所述抓包管理系统的调试代理工具Whistle获取所述远程网络服务器的响应内容,并将响应内容发送给客户端,将用户服务请求信息和响应内容信息发布到消息队列RabbitMQ中。
所述将用户服务请求信息和响应内容信息发布到消息队列RabbitMQ中包括:
依据所述消息队列RabbitMQ中响应内容信息数量,获取所述客户端的连接数量。
根据本发明的多用户在线代理抓包调试的方案,通过所述客户端向抓包管理系统发送服务请求信息;所述抓包管理系统的调试代理工具Whistle依据所述客户端的配置规则,将所述服务请求信息转发至目标服务器;所述目标服务器的本地文件模拟工具依据所述服务请求信息的统一资源定位符URL按照设定规则转化的文件名,并解析所述文件名对应的文件内容,或将用户服务请求信息发送至远程网络服务器;所述抓包管理系统的调试代理工具Whistle获取所述远程网络服务器的响应内容,并将响应内容发送给客户端,将用户服务请求信息和响应内容信息发布到消息队列RabbitMQ中。本申请可以使多个用户同时在线使用代理服务,方便做服务扩展,能够实现多用户之间的数据或配置共享。。
应该理解的是,虽然图4、图5的流程图中的各个步骤按照箭头的指示依次显示,但是这些步骤并不是必然按照箭头指示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,这些步骤可以以其它的顺序执行。而且,图4、图5中的至少一部分步骤可以包括多个子步骤或者多个阶段,这些子步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,这些子步骤或者阶段的执行顺序也不必然是依次进行,而是可以与其它步骤或者其它步骤的子步骤或者阶段的至少一部分轮流或者交替地执行。
应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员应当理解在本文所公开的示例中的设备的模块或单元或组件可以布置在如该实施例中所描述的设备中,或者可替换地可以定位在与该示例中的设备不同的一个或多个设备中。前述示例中的模块可以组合为一个模块或者此外可以分成多个子模块。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
此外,所述实施例中的一些在此被描述成可以由计算机系统的处理器或者由执行所述功能的其它装置实施的方法或方法元素的组合。因此,具有用于实施所述方法或方法元素的必要指令的处理器形成用于实施该方法或方法元素的装置。此外,装置实施例的在此所述的元素是如下装置的例子:该装置用于实施由为了实施该发明的目的的元素所执行的功能。
如在此所使用的那样,除非另行规定,使用序数词“第一”、“第二”、“第三”等等来描述普通对象仅仅表示涉及类似对象的不同实例,并且并不意图暗示这样被描述的对象必须具有时间上、空间上、排序方面或者以任意其它方式的给定顺序。
尽管根据有限数量的实施例描述了本发明,但是受益于上面的描述,本技术领域内的技术人员明白,在由此描述的本发明的范围内,可以设想其它实施例。此外,应当注意,本说明书中使用的语言主要是为了可读性和教导的目的而选择的,而不是为了解释或者限定本发明的主题而选择的。因此,在不偏离所附权利要求书的范围和精神的情况下,对于本技术领域的普通技术人员来说许多修改和变更都是显而易见的。对于本发明的范围,对本发明所做的公开是说明性的,而非限制性的,本发明的范围由所附权利要求书限定。
Claims (10)
1.一种多用户在线代理抓包调试的方法,所述方法通过抓包管理系统将多个客户端的请求传递给目标服务器,并根据目标服务器的处理规则响应客户端的请求,实现多用户在线代理抓包调试,所述方法包括步骤:
所述客户端向抓包管理系统发送服务请求信息,所述抓包管理系统包括代理端口、代理服务器、进程管理工具PM2、调试代理工具Whistle;
依据所述客户端向抓包管理系统发送的服务请求信息,所述抓包管理系统的调试代理工具Whistle依据所述客户端的配置规则,将所述服务请求信息转发至目标服务器,所述目标服务器包括远程网络服务器、中间件Middleware、本地文件模拟工具;
依据所述抓包管理系统的调试代理工具Whistle将所述服务请求信息转发至目标服务器,所述目标服务器的本地文件模拟工具依据所述服务请求信息的统一资源定位符URL按照设定规则转化的文件名,并解析所述文件名对应的文件内容,或将用户服务请求信息发送至远程网络服务器;
依据所述目标服务器的本地文件模拟工具依据所述服务请求信息的统一资源定位符URL按照设定规则转化的文件名,并解析所述文件名对应的文件内容,或将用户服务请求信息发送至远程网络服务器,所述抓包管理系统的调试代理工具Whistle获取所述远程网络服务器的响应内容,并将响应内容发送给客户端,将用户服务请求信息和响应内容信息发布到消息队列RabbitMQ中。
2.如权利要求1所述的方法,其中,所述客户端向抓包管理系统发送服务请求信息的步骤包括:
客户端通过用户登录账号登录抓包管理系统;
依据所述客户端通过用户登录账号登录抓包管理系统,客户端选择抓包管理系统的一个代理端口,并连接所述代理端口指向的代理服务器;
客户端生成服务请求信息,并向所述代理端口发送HTTP请求,将所述服务请求信息通过代理端口发送至指向的代理服务器。
3.如权利要求1所述的方法,其中,所述抓包管理系统的调试代理工具Whistle依据所述客户端的配置规则,将所述服务请求信息转发至目标服务器的步骤包括:
所述抓包管理系统的代理服务器将所述客户端的服务请求信息转发至所述抓包管理系统的进程管理工具PM2;
所述抓包管理系统的进程管理工具PM2将所述服务请求信息转发至所述抓包管理系统的调试代理工具Whistle;
所述抓包管理系统的调试代理工具Whistle根据所述客户端的配置规则,将所述服务请求信息转发至目标服务器。
4.如权利要求1所述的方法,其中,所述目标服务器的本地文件模拟工具依据所述服务请求信息的统一资源定位符URL按照设定规则转化的文件名,并解析所述文件名对应的文件内容,或将用户服务请求信息发送至远程网络服务器的步骤包括:
所述本地文件模拟工具获取所述抓包管理系统的调试代理工具Whistle转发的客户端服务请求信息;
依据所述客户端的服务请求信息,所述本地文件模拟工具获取所述服务请求信息所对应的统一资源定位符URL;
依据所述服务请求信息所对应的统一资源定位符URL,所述本地文件模拟工具按照设定的规则将根据所述服务请求信息所对应的统一资源定位符URL转换为文件名;
依据所述统一资源定位符URL转换的文件名,所述本地文件模拟工具查找所述文件名对应的文件;
如果查找到对应的文件,所述本地文件模拟工具解析所述文件内容,并执行所述文件内容的代码;
如果查找不到所述统一资源定位符URL转换的文件名对应的文件,所述目标服务器将所述客户端的服务请求信息转发至远程网络服务器。
5.如权利要求4所述的方法,其中,所述本地文件模拟工具按照设定的规则将根据所述服务请求信息所对应的统一资源定位符URL转换为文件名的步骤包括:
依据所述服务请求信息所对应的统一资源定位符URL,所述本地文件模拟工具获取所述统一资源定位符URL的最后一段路径,以及所述统一资源定位符URL的某一个参数值;
依据所述本地文件模拟工具获取所述统一资源定位符URL的最后一段路径,以及所述统一资源定位符URL的某一个参数值,获取所述统一资源定位符URL的最后一段路径,及所述统一资源定位符URL的某一个参数值的配配置;
依据所述统一资源定位符URL的最后一段路径,及所述统一资源定位符URL的某一个参数值的配配置,递归指定文件目录下的所有文件;
依据所述递归指定文件目录下的所有文件,获取所述统一资源定位符URL转换的文件名。
6.如权利要求4所述的方法,其中,所述本地文件模拟工具查找所述文件名对应的文件,解析所述文件内容,并执行所述文件内容的代码的步骤包括:
本地文件模拟工具查找所述文件名所匹配的文件,所述文件名包括文件扩展名;
如果查找到匹配文件,则获取所述文件内容,并解析所述文件内容头部定义的元数据;
如果查找不到匹配文件,则本地文件模拟工具查找所述文件名不包括扩展名时所匹配的文件;
如果查找到匹配文件,则获取所述文件内容,并解析所述文件内容头部定义的元数据;
所述本地文件模拟工具判断所述文件内容头部定义的元数据中开关状态MEAT status指令的状态是否为关闭;
如果未关闭,则所述本地文件模拟工具判断所述文件内容头部定义的元数据中解析类型MEAT openType指令是否有效;
如果有效,则并行执行所述文件内容头部定义的元数据中raw-comments-json指令、require-promise指令、require-raw指令、require-function指令,并返回相应执行结果;
所述本地文件模拟工具判断所述文件内容头部定义的元数据中MEAT wait指令是否为有效数字;
如果是有效数字,则执行所述MEAT wait指令的延迟事件后返回执行结果;
所述本地文件模拟工具将所述文件内容的代码执行结果返回至所述抓包管理系统的调试代理工具Whistle;
如果所述本地文件模拟工具查找不到所述文件名对应的文件,则所述目标服务器将所述客户端的服务请求信息转发至远程网络服务器。
7.如权利要求1所述的方法,其中,所述将用户服务请求信息和响应内容信息发布到消息队列RabbitMQ中包括:
依据所述消息队列RabbitMQ中响应内容信息数量,获取所述客户端的连接数量。
8.一种电子设备,包括:
一个或多个处理器;和存储器;
一个或多个程序,其中所述一个或多个程序存储在所述存储器中并被配置为由所述一个或多个处理器执行,所述一个或多个程序包括用于执行根据权利要求1-7所述的方法中的任一方法的指令。
9.一种多用户在线代理转包调试系统,其特征在于,所述系统包括权利要求8所述的电子设备,所述电子设备用于执行根据权利要求1-7所述的方法中的任一方法的指令。
10.一种存储一个或多个程序的计算机可读存储介质,所述一个或多个程序包括指令,所述指令当计算设备执行时,使得所述计算设备执行根据权利要求1-7所述的方法中的任一方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210806782.2A CN115348246A (zh) | 2022-07-08 | 2022-07-08 | 多用户在线代理抓包调试的方法、设备、系统及介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210806782.2A CN115348246A (zh) | 2022-07-08 | 2022-07-08 | 多用户在线代理抓包调试的方法、设备、系统及介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN115348246A true CN115348246A (zh) | 2022-11-15 |
Family
ID=83947634
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210806782.2A Pending CN115348246A (zh) | 2022-07-08 | 2022-07-08 | 多用户在线代理抓包调试的方法、设备、系统及介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115348246A (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN117909055A (zh) * | 2024-03-18 | 2024-04-19 | 北京壁仞科技开发有限公司 | 处理器的前端电路和抓包控制方法 |
-
2022
- 2022-07-08 CN CN202210806782.2A patent/CN115348246A/zh active Pending
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN117909055A (zh) * | 2024-03-18 | 2024-04-19 | 北京壁仞科技开发有限公司 | 处理器的前端电路和抓包控制方法 |
CN117909055B (zh) * | 2024-03-18 | 2024-06-11 | 北京壁仞科技开发有限公司 | 处理器的前端电路和抓包控制方法 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10320623B2 (en) | Techniques for tracking resource usage statistics per transaction across multiple layers of protocols | |
CN111427766B (zh) | 一种请求处理方法、装置和代理服务器 | |
US8078691B2 (en) | Web page load time prediction and simulation | |
US8438251B2 (en) | Methods and systems for implementing a virtual storage network | |
JP4398462B2 (ja) | ウェブ・デバイスにおけるhtmlページの提示を改善するための方法およびシステム | |
CN107688538B (zh) | 一种脚本执行方法、装置及计算设备 | |
US7496658B2 (en) | Systems and methods for testing network services | |
CN109871354B (zh) | 一种文件处理的方法及装置 | |
CN112199567A (zh) | 一种分布式数据采集方法、系统、服务器和存储介质 | |
JP5604016B1 (ja) | スクリプトのキャッシュ方法及びそれを適用した情報処理装置 | |
US9892202B2 (en) | Web page load time reduction by optimized authentication | |
CN115348246A (zh) | 多用户在线代理抓包调试的方法、设备、系统及介质 | |
CN112732468B (zh) | 数据处理方法、数据交互系统及计算设备 | |
JPWO2004086246A1 (ja) | 分散処理制御装置、分散処理制御方法および分散処理制御プログラム | |
CN112491940B (zh) | 代理服务器的请求转发方法及装置、存储介质及电子设备 | |
CN112394907A (zh) | 基于容器的交付系统构建方法、应用交付方法和交付系统 | |
CN112115056A (zh) | 一种项目部署方法和装置、服务器、存储介质 | |
US20230088115A1 (en) | Generating early hints informational responses at an intermediary server | |
US9489215B2 (en) | Managing an expression-based DFA construction process | |
CN111338928A (zh) | 基于chrome浏览器测试的方法及装置 | |
CN111953718A (zh) | 一种页面调试方法和装置 | |
US20150032789A1 (en) | Dynamic object oriented remote instantiation | |
US11263325B2 (en) | System and method for application exploration | |
JP2004094411A (ja) | 広域ネットワーク内の透過的な作業環境を有するシン−クライアントのローミングシステムおよび方法 | |
US10878187B1 (en) | Network-based content rendering |
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 |