CN116303486A - 前端操作拦截处理方法、装置、计算机设备及存储介质 - Google Patents
前端操作拦截处理方法、装置、计算机设备及存储介质 Download PDFInfo
- Publication number
- CN116303486A CN116303486A CN202310004758.1A CN202310004758A CN116303486A CN 116303486 A CN116303486 A CN 116303486A CN 202310004758 A CN202310004758 A CN 202310004758A CN 116303486 A CN116303486 A CN 116303486A
- Authority
- CN
- China
- Prior art keywords
- interception
- interception capability
- end operation
- request
- field
- 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
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/23—Updating
- G06F16/2358—Change logging, detection, and notification
-
- 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/445—Program loading or initiating
- G06F9/44521—Dynamic linking or loading; Link editing at or after load time, e.g. Java class loading
- G06F9/44526—Plug-ins; Add-ons
-
- 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/46—Multiprogramming arrangements
- G06F9/48—Program initiating; Program switching, e.g. by interrupt
- G06F9/4806—Task transfer initiation or dispatching
- G06F9/4843—Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- Stored Programmes (AREA)
Abstract
本申请实施例属于数据处理技术领域,涉及一种前端操作拦截处理方法、装置、计算机设备及存储介质,方法包括:接收前端操作请求,根据前端操作请求获取操作类型和操作动作;基于前端操作请求创建拦截能力处理器对象,并基于拦截能力处理器对象创建至少一个拦截能力对象,判断是否存在与操作类型和操作动作匹配的拦截能力对象;若包含则基于拦截能力处理器对象和匹配的拦截能力对象调用相应的插件对前端操作请求进行拦截处理,否则直接对前端操作请求进行处理;根据前端操作请求的处理结果更新数据库,并向前端反馈处理结果。本申请可以实现对前端操作的多种操作类型的拦截,对系统侵入性小,有利于提高系统开发效率和稳定性。
Description
技术领域
本申请涉及数据处理技术领域,尤其涉及一种前端操作拦截处理方法、装置、计算机设备及存储介质。
背景技术
对于具有前端和后端的系统,前端进行item操作发起新增或更新数据的请求时,后端接口拦截该请求,通过插件对该请求进行相关数据处理并返回处理结果,以实现在数据库中的数据新增或更新,并将新增或更新数据反馈至前端。目前系统常见的插件接口拦截行为仅局限于后端接口中间切片层的拦截,难以对操作动作以及item类型进行判断,同时当前的拦截方式仅支持单一的item类型拦截,若要新增其他item类型,需要大量重复冗余的代码,无法实现系统敏捷开发,且需针对不同的item类型的拦截编写不同的处理方式,插件处理代码侵入性强,破坏系统原有的代码。
发明内容
本申请实施例的目的在于提出一种前端操作拦截处理方法、装置、计算机设备及存储介质,以解决现有技术拦截前端操作进行数据处理更新时存在的无法对操作动作以及操作类型进行判断,仅支撑单一操作类型拦截处理的问题。
为了解决上述技术问题,本申请实施例提供一种前端操作拦截处理方法,所述方法包括:
接收前端操作请求,根据所述前端操作请求获取操作类型和操作动作;
基于所述前端操作请求创建拦截能力处理器对象,并基于所述拦截能力处理器对象创建至少一个拦截能力对象,判断是否存在与所述操作类型和所述操作动作匹配的拦截能力对象;
若包含则基于所述拦截能力处理器对象和匹配的拦截能力对象调用相应的插件,通过所述插件对所述前端操作请求进行拦截处理,否则直接对所述前端操作请求进行处理;
根据所述前端操作请求的处理结果更新数据库,并向前端反馈所述处理结果。
进一步地,所述基于所述拦截能力处理器对象创建至少一个拦截能力对象,判断是否存在与所述操作类型和所述操作动作匹配的拦截能力对象的步骤包括:
获取所述拦截能力处理器对象的拦截能力列表字段,基于所述拦截能力列表字段进行初始化,得到拦截能力列表;
基于所述拦截能力列表中的字段值创建至少一个拦截能力对象,所述拦截能力对象至少包含关注操作类型字段和关注操作动作字段;
判断所述关注操作类型字段和所述关注操作动作字段的字段值是否匹配所述操作类型和所述操作动作,以获取匹配所述操作类型和所述操作动作的拦截能力对象。
进一步地,当匹配的所述拦截能力对象具有多个时,所述通过所述插件对所述前端操作请求进行拦截处理的步骤包括:
根据所述前端操作请求获取待操作数据,将所述操作类型、所述操作动作以及所述待操作数据发送至多个插件,接收多个插件的初始处理结果,将多个初始处理结果进行合并后得到所述处理结果。
进一步地,在所述将所述操作类型、所述操作动作以及所述待操作数据发送至多个插件的步骤之后,所述方法还包括:
获取各插件基于所述操作类型、所述操作动作以及所述待操作数据生成的预处理信息;
基于所述预处理信息判断各所述插件是否就绪,以基于就绪的插件对所述前端操作请求进行拦截处理。
进一步地,当所述关注操作类型字段和所述关注操作动作字段的字段值为空时,所述方法还包括:
获取所述关注操作类型字段和所述关注操作动作字段的字段值为空的拦截能力对象,将其作为与所述操作类型和所述操作动作匹配的拦截能力对象。
进一步地,所述根据所述前端操作请求获取操作类型和操作动作的步骤包括:
读取所述前端操作请求的请求信息,解析所述请求信息得到所述操作类型和所述操作动作;或
根据所述前端操作请求调用GraphQL接口,读取所述GraphQL接口的接口参数,进行接口参数解析得到所述操作类型和所述操作动作。
进一步地,在所述基于所述拦截能力列表字段的字段值创建至少一个拦截能力对象的步骤之前,所述方法还包括:
获取多个插件的配置文件,从各所述配置文件中获取对应的插件的关注操作类型字段和关注操作动作字段的字段值;
基于从所述配置文件中获取的多个字段值生成与所述拦截能力列表字段对应的拦截能力列表。
为了解决上述技术问题,本申请实施例还提供一种前端操作拦截处理装置,包括:
接收模块,用于接收前端操作请求,根据所述前端操作请求获取操作类型和操作动作;
处理模块,用于基于所述前端操作请求创建拦截能力处理器对象,并基于所述拦截能力处理器对象创建至少一个拦截能力对象,判断是否存在与所述操作类型和所述操作动作匹配的拦截能力对象,若包含则基于所述拦截能力处理器对象和匹配的拦截能力对象调用相应的插件,通过所述插件对所述前端操作请求进行拦截处理,否则直接对所述前端操作请求进行处理;
更新反馈模块,用于根据所述前端操作请求的处理结果更新数据库,并向前端反馈所述处理结果。
为了解决上述技术问题,本申请实施例还提供一种计算机设备,包括存储器和处理器,所述存储器中存储有计算机程序,所述处理器执行所述计算机程序时实现如上所述的前端操作拦截处理方法的步骤。
为了解决上述技术问题,本申请实施例还提供一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如上所述的前端操作拦截处理方法的步骤。
与现有技术相比,本申请实施例主要有以下有益效果:
本申请实施例的方案基于面向对象的方式,通过创建拦截能力处理器对象和拦截能力对象来确定对应的插件对前端操作请求进行拦截处理,可以实现对前端操作的多种操作类型的拦截,且可针对不同的前端操作类型的拦截处理,无需针对不同的前端操作类型对系统原有代码进行不同处理方式的修改,对系统侵入性小,有利于提高系统开发效率和稳定性。
附图说明
为了更清楚地说明本申请中的方案,下面将对本申请实施例描述中所需要使用的附图作一个简单介绍,显而易见地,下面描述中的附图是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本申请可以应用于其中的示例性系统架构图;
图2是根据本申请的前端操作拦截处理方法的一个实施例的流程图;
图3是根据本申请的前端操作拦截处理装置的一个实施例的结构示意图;
图4是根据本申请的计算机设备的一个实施例的结构示意图。
具体实施方式
除非另有定义,本文所使用的所有的技术和科学术语与属于本申请的技术领域的技术人员通常理解的含义相同;本文中在申请的说明书中所使用的术语只是为了描述具体的实施例的目的,不是旨在于限制本申请;本申请的说明书和权利要求书及上述附图说明中的术语“包括”和“具有”以及它们的任何变形,意图在于覆盖不排他的包含。本申请的说明书和权利要求书或上述附图中的术语“第一”、“第二”等是用于区别不同对象,而不是用于描述特定顺序。
在本文中提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本申请的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其它实施例互斥的独立的或备选的实施例。本领域技术人员显式地和隐式地理解的是,本文所描述的实施例可以与其它实施例相结合。
为了使本技术领域的人员更好地理解本申请方案,下面将结合附图,对本申请实施例中的技术方案进行清楚、完整地描述。
如图1所示,系统架构100可以包括终端设备101、102、103,网络104和服务器105。网络104用以在终端设备101、102、103和服务器105之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备101、102、103通过网络104与服务器105交互,以接收或发送消息等。终端设备101、102、103上可以安装有各种通讯客户端应用,例如网页浏览器应用、购物类应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等。
终端设备101、102、103可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。
服务器105可以是提供各种服务的服务器,例如对终端设备101、102、103上显示的页面提供支持的后台服务器。
需要说明的是,本申请实施例所提供的前端操作拦截处理方法一般由服务器执行,相应地,前端操作拦截处理装置一般设置于服务器中。
应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
继续参考图2,示出了根据本申请的前端操作拦截处理的方法的一个实施例的流程图。所述的前端操作拦截处理方法包括以下步骤S201至S206:
步骤S201,接收前端操作请求,根据所述前端操作请求获取操作类型和操作动作。
在本实施例中,当用户在前端进入操作界面对界面中item进行操作时,将向后端发送操作请求,后端接收前端操作请求后可根据所述前端操作请求来获取操作类型(ItemType)和操作动作(action),以基于所述操作类型和操作动作来进行后续的处理。
在本实施例中,所述前端操作拦截处理方法运行于其上的电子设备(例如图1所示的服务器)可以通过有线连接方式或者无线连接方式接收前端操作请求。需要指出的是,上述无线连接方式可以包括但不限于3G/4G连接、WiFi连接、蓝牙连接、WiMAX连接、Zigbee连接、UWB(ultra wideband)连接、以及其他现在已知或将来开发的无线连接方式。
在一些实施例中,所述根据所述前端操作请求获取操作类型和操作动作的步骤包括:读取所述前端操作请求的请求信息,解析所述请求信息得到所述操作类型和所述操作动作。本实施例直接通过解析所述前端操作的请求信息来获得操作类型和操作动作。
在另一些实施例中,所述根据所述前端操作请求获取操作类型和操作动作的步骤包括:根据所述前端操作请求调用GraphQL接口,读取所述GraphQL接口的接口参数,进行接口参数解析得到所述操作类型和所述操作动作。在本实施例中,当存在多个前端时,在各个itemType的接口,埋入item拦截能力相关的itemType和action,多个前端操作都收敛于一个GraphQL接口,通过对GraphQL接口的参数解析获得对应的itemType和action,即通过少量的代码注入即可实现不同类型的itemType的拦截。
步骤S202,基于所述前端操作请求创建拦截能力处理器对象,并基于所述拦截能力处理器对象创建至少一个拦截能力对象。本步骤具体通过获取所述拦截能力处理器对象的拦截能力列表字段,基于所述拦截能力列表字段进行初始化,得到拦截能力列表,再基于所述拦截能力列表中的字段值创建至少一个拦截能力对象,所述拦截能力对象至少包含关注操作类型字段和关注操作动作字段。
在本申请具体实施例中,可定义所述拦截能力处理器对象的对象名为ItemHandlerController,所述拦截能力处理器对象包含的拦截能力列表字段的字段名为matchAbilities,其字段值存储于当前系统所注册的拦截能力列表,此外所述拦截能力处理器对象,包含有如下四个方法:
1)HasAbilityMatch,该方法用于确定当前系统是否有能力匹配到与所述操作类型和操作动作相对应的插件。
2)ExecutePreAction,该方法用于执行调用匹配的拦截能力对象对应的插件的能力方法preAction。
3)HasAbilityFollow,该方法用于确定匹配到的插件是否有能力follow,也即匹配到的插件是否会响应处理请求。
4)ExecuteActionDone,该方法用于执行调用匹配的拦截能力对象对应的插件能力方法actionDone。
同时,可定义拦截能力对象的对象名为ItemHandlerAbility,其除了包含关注操作类型字段和关注操作动作字段,还包括如下两个方法供上述拦截能力处理器对象的ExecutePreAction和ExecuteActionDone来调用:
1)调用插件的preAction。
2)调用插件的actionDone。
基于上述两个对象,本方案可实现面向对象编程,所述拦截能力对象将拦截能力抽象为一个对象,逻辑清晰,通过将调用插件的方法挂载到拦截能力对象上,减少了冗余代码。所述拦截能力处理器对象可针对不同的操作类型的拦截进行抽象,不用每个操作类型写一次逻辑处理代码,大大减少了对标品原有代码的侵入。
当基于所述前端操作请求创建拦截能力处理器对象,并基于所述拦截能力处理器对象创建至少一个拦截能力对象时,具体创建一个ItemHandlerController对象,先获取当前系统注册的拦截能力列表,然后过滤出符合条件的“itemType”和“action”的拦截能力对象ItemHandlerAbility,再通过调用拦截能力对象ItemHandlerAbility的方法执行后续步骤,即调用插件的preAction,得到最终落盘(即后续步骤的处理结果存入数据库的过程)的返回值(即后续步骤中的处理结果),然后执行系统原有的方法落盘,并在落盘的代码后面,加入调用拦截能力对象ItemHandlerAbility的方法来调用插件的actionDone完成处理结果的落盘通知。
在一些实施例中,在所述基于所述拦截能力列表字段的字段值创建至少一个拦截能力对象的步骤之前,所述方法还包括:获取多个插件的配置文件,从各所述配置文件中获取对应的插件的关注操作类型字段和关注操作动作字段的字段值;基于从所述配置文件中获取的多个字段值生成与所述拦截能力列表字段对应的拦截能力列表。具体的,对于插件侧,插件将需要用到itemType和action提前定义到配置文件plugin.yaml中,或者通过特定的工具工具添加拦截能力,以达到系统在不激活插件的情况下即可知道当前插件拦截的itemType和action,实现按需激活插件,系统逻辑与插件实际代码解耦,可提高插件开发效率。
步骤S203,判断是否存在与所述操作类型和所述操作动作匹配的拦截能力对象。若是则执行步骤S204,否者执行步骤S205;本步骤具体包括判断所述关注操作类型字段和所述关注操作动作字段的字段值是否匹配所述操作类型和所述操作动作,以获取匹配所述操作类型和所述操作动作的拦截能力对象。实际上每个拦截能力对象包含一个插件所关注的操作类型和操作动作,比如用户在操作界面更新工作项标题,则操作类型为user,操作动作为update,此二者通过前端操作请求发送至后端,如果插件关注了此操作类型和操作动作,即所述关注操作类型字段和所述关注操作动作字段的字段值分别为user和update,此时通过字段匹配即可获得匹配所述操作类型和所述操作动作的拦截能力对象。
在一些实施例,当所述关注操作类型字段和所述关注操作动作字段的字段值为空时,所述方法还包括:获取所述关注操作类型字段和所述关注操作动作字段的字段值为空的拦截能力对象,将其作为与所述操作类型和所述操作动作匹配的拦截能力对象。在本实施例中,当插件没有关注的操作类型和操作动作时,当发生前端操作请求时,该插件都将被激活,被激活的插件再基于前端操作请求中的信息决定是否响应该前端操作请求来进行处理,使得前端操作请求在没有被关注的情况下也可以被第三方的插件选择性拦截处理。
步骤S204,基于所述拦截能力处理器对象和匹配的拦截能力对象调用相应的插件,通过所述插件对所述前端操作请求进行拦截处理。
在本实施例中,匹配的所述拦截能力对象具有一个或多个,相应地调用的插件也为一个或多个,当匹配的所述拦截能力对象具有多个时,所述通过所述插件对所述前端操作请求进行拦截处理的步骤包括:根据所述前端操作请求获取待操作数据,将所述操作类型、所述操作动作以及所述待操作数据发送至多个插件,接收多个插件的初始处理结果,将多个初始处理结果进行合并后得到所述处理结果。通过本实施例可以获得完整的数据处理结果。
在一些实施例中,在所述将所述操作类型、所述操作动作以及所述待操作数据发送至多个插件的步骤之后,所述方法还包括:获取各插件基于所述操作类型、所述操作动作以及所述待操作数据生成的预处理信息;基于所述预处理信息判断各所述插件是否就绪,以基于就绪的插件对所述前端操作请求进行拦截处理。在本实施例中,当调用多个插件时,被调用的插件也将根据接收的信息来决定是否对前端操作请求进行拦截处理,提高系统处理的灵活性。
步骤S205,直接对所述前端操作请求进行处理。本步骤提供另一种处理方式,可在没有调用插件的情况下通过后端原本的处理流程进行前端操作请求的处理。
步骤S206,根据所述前端操作请求的处理结果更新数据库,并向前端反馈所述处理结果。本步骤完成数据的落盘操作,同时将相关信息发送至前端显示。
与现有技术相比,本申请实施例主要有以下有益效果:
本申请实施例的方案基于面向对象的方式,通过创建拦截能力处理器对象和拦截能力对象来确定对应的插件对前端操作请求进行拦截处理,可以实现对前端操作的多种操作类型的拦截,且可针对不同的前端操作类型的拦截处理,无需针对不同的前端操作类型对系统原有代码进行不同处理方式的修改,对系统侵入性小,有利于提高系统开发效率和稳定性。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,该计算机程序可存储于一计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,前述的存储介质可为磁碟、光盘、只读存储记忆体(Read-Only Memory,ROM)等非易失性存储介质,或随机存储记忆体(Random Access Memory,RAM)等。
应该理解的是,虽然附图的流程图中的各个步骤按照箭头的指示依次显示,但是这些步骤并不是必然按照箭头指示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,其可以以其他的顺序执行。而且,附图的流程图中的至少一部分步骤可以包括多个子步骤或者多个阶段,这些子步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,其执行顺序也不必然是依次进行,而是可以与其他步骤或者其他步骤的子步骤或者阶段的至少一部分轮流或者交替地执行。
进一步参考图3,作为对上述图2所示方法的实现,本申请提供了一种前端操作拦截处理装置的一个实施例,该装置实施例与图2所示的方法实施例相对应,该装置具体可以应用于各种电子设备中。
如图3所示,本实施例所述的前端操作拦截处理装置包括:接收模块301、处理模块302以及更新反馈模块303。其中:
所述接收模块301用于接收前端操作请求,根据所述前端操作请求获取操作类型和操作动作;
所述处理模块302用于基于所述前端操作请求创建拦截能力处理器对象,并基于所述拦截能力处理器对象创建至少一个拦截能力对象,判断是否存在与所述操作类型和所述操作动作匹配的拦截能力对象,若包含则基于所述拦截能力处理器对象和匹配的拦截能力对象调用相应的插件,通过所述插件对所述前端操作请求进行拦截处理,否则直接对所述前端操作请求进行处理;
所述更新反馈模块303用于根据所述前端操作请求的处理结果更新数据库,并向前端反馈所述处理结果。
在本实施例中,所述处理模块302基于所述拦截能力处理器对象创建至少一个拦截能力对象,判断是否存在与所述操作类型和所述操作动作匹配的拦截能力对象时,具体用于:获取所述拦截能力处理器对象的拦截能力列表字段,基于所述拦截能力列表字段进行初始化,得到拦截能力列表;基于所述拦截能力列表中的字段值创建至少一个拦截能力对象,所述拦截能力对象至少包含关注操作类型字段和关注操作动作字段;判断所述关注操作类型字段和所述关注操作动作字段的字段值是否匹配所述操作类型和所述操作动作,以获取匹配所述操作类型和所述操作动作的拦截能力对象。
在本实施例中,当匹配的所述拦截能力对象具有多个时,所述处理模块302通过所述插件对所述前端操作请求进行拦截处理时,具体用于:根据所述前端操作请求获取待操作数据,将所述操作类型、所述操作动作以及所述待操作数据发送至多个插件,接收多个插件的初始处理结果,将多个初始处理结果进行合并后得到所述处理结果。
在本实施例中,所述处理模块302在所述将所述操作类型、所述操作动作以及所述待操作数据发送至多个插件之后,还用于:获取各插件基于所述操作类型、所述操作动作以及所述待操作数据生成的预处理信息;基于所述预处理信息判断各所述插件是否就绪,以基于就绪的插件对所述前端操作请求进行拦截处理。
在本实施例中,当所述关注操作类型字段和所述关注操作动作字段的字段值为空时,所述处理模块302还用于:获取所述关注操作类型字段和所述关注操作动作字段的字段值为空的拦截能力对象,将其作为与所述操作类型和所述操作动作匹配的拦截能力对象。
在本实施例中,所述接收模块301根据所述前端操作请求获取操作类型和操作动作时,具体用于:读取所述前端操作请求的请求信息,解析所述请求信息得到所述操作类型和所述操作动作。
在另一实施例中,所述接收模块301根据所述前端操作请求获取操作类型和操作动作时,具体用于:根据所述前端操作请求调用GraphQL接口,读取所述GraphQL接口的接口参数,进行接口参数解析得到所述操作类型和所述操作动作。
在本实施例中,所述处理模块302在基于所述拦截能力列表字段的字段值创建至少一个拦截能力对象之前,还用于:获取多个插件的配置文件,从各所述配置文件中获取对应的插件的关注操作类型字段和关注操作动作字段的字段值;基于从所述配置文件中获取的多个字段值生成与所述拦截能力列表字段对应的拦截能力列表。
上述各模块在执行相关操作时,各操作具体涉及的技术内容可参考上述方法实施例中的相关内容,在此不作展开。
与现有技术相比,本申请实施例主要有以下有益效果:
本申请实施例的方案基于面向对象的方式,通过创建拦截能力处理器对象和拦截能力对象来确定对应的插件对前端操作请求进行拦截处理,可以实现对前端操作的多种操作类型的拦截,且可针对不同的前端操作类型的拦截处理,无需针对不同的前端操作类型对系统原有代码进行不同处理方式的修改,对系统侵入性小,有利于提高系统开发效率和稳定性。
为了解决上述技术问题,本申请实施例还提供一种计算机设备,包括存储器和处理器,所述存储器中存储有计算机程序,所述处理器执行所述计算机程序时实现如上所述的前端操作拦截处理方法的步骤,并具有相应的技术效果。
具体请参阅图4,图4为本实施例计算机设备基本结构框图。所述计算机设备4包括通过系统总线相互通信连接存储器41、处理器42、网络接口43。需要指出的是,图中仅示出了具有组件41-43的计算机设备4,但是应理解的是,并不要求实施所有示出的组件,可以替代的实施更多或者更少的组件。其中,本技术领域技术人员可以理解,这里的计算机设备是一种能够按照事先设定或存储的指令,自动进行数值计算和/或信息处理的设备,其硬件包括但不限于微处理器、专用集成电路(Application Specific Integrated Circuit,ASIC)、可编程门阵列(Field-Programmable Gate Array,FPGA)、数字处理器(DigitalSignal Processor,DSP)、嵌入式设备等。
所述计算机设备可以是桌上型计算机、笔记本、掌上电脑及云端服务器等计算设备。所述计算机设备可以与用户通过键盘、鼠标、遥控器、触摸板或声控设备等方式进行人机交互。
所述存储器41至少包括一种类型的可读存储介质,所述可读存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,SD或DX存储器等)、随机访问存储器(RAM)、静态随机访问存储器(SRAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、可编程只读存储器(PROM)、磁性存储器、磁盘、光盘等。在一些实施例中,所述存储器41可以是所述计算机设备4的内部存储单元,例如该计算机设备4的硬盘或内存。在另一些实施例中,所述存储器41也可以是所述计算机设备4的外部存储设备,例如该计算机设备4上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(FlashCard)等。当然,所述存储器41还可以既包括所述计算机设备4的内部存储单元也包括其外部存储设备。本实施例中,所述存储器41通常用于存储安装于所述计算机设备4的操作系统和各类应用软件,例如前端操作拦截处理方法的程序代码等。此外,所述存储器41还可以用于暂时地存储已经输出或者将要输出的各类数据。
所述处理器42在一些实施例中可以是中央处理器(Central Processing Unit,CPU)、控制器、微控制器、微处理器、或其他数据处理芯片。该处理器42通常用于控制所述计算机设备4的总体操作。本实施例中,所述处理器42用于运行所述存储器41中存储的程序代码或者处理数据,例如运行所述前端操作拦截处理方法的程序代码。
所述网络接口43可包括无线网络接口或有线网络接口,该网络接口43通常用于在所述计算机设备4与其他电子设备之间建立通信连接。
为了解决上述技术问题,本申请实施例还提供一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机程序,所述计算机程序程序可被至少一个处理器执行,以使所述至少一个处理器执行如上述的前端操作拦截处理方法的步骤,并具有相应的技术效果。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本申请各个实施例所述的方法。
显然,以上所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例,附图中给出了本申请的较佳实施例,但并不限制本申请的专利范围。本申请可以以许多不同的形式来实现,相反地,提供这些实施例的目的是使对本申请的公开内容的理解更加透彻全面。尽管参照前述实施例对本申请进行了详细的说明,对于本领域的技术人员来而言,其依然可以对前述各具体实施方式所记载的技术方案进行修改,或者对其中部分技术特征进行等效替换。凡是利用本申请说明书及附图内容所做的等效结构,直接或间接运用在其他相关的技术领域,均同理在本申请专利保护范围之内。
Claims (10)
1.一种前端操作拦截处理方法,其特征在于,所述方法包括:
接收前端操作请求,根据所述前端操作请求获取操作类型和操作动作;
基于所述前端操作请求创建拦截能力处理器对象,并基于所述拦截能力处理器对象创建至少一个拦截能力对象,判断是否存在与所述操作类型和所述操作动作匹配的拦截能力对象;
若包含则基于所述拦截能力处理器对象和匹配的拦截能力对象调用相应的插件,通过所述插件对所述前端操作请求进行拦截处理,否则直接对所述前端操作请求进行处理;
根据所述前端操作请求的处理结果更新数据库,并向前端反馈所述处理结果。
2.根据权利要求1所述的前端操作拦截处理方法,其特征在于,所述基于所述拦截能力处理器对象创建至少一个拦截能力对象,判断是否存在与所述操作类型和所述操作动作匹配的拦截能力对象的步骤包括:
获取所述拦截能力处理器对象的拦截能力列表字段,基于所述拦截能力列表字段进行初始化,得到拦截能力列表;
基于所述拦截能力列表中的字段值创建至少一个拦截能力对象,所述拦截能力对象至少包含关注操作类型字段和关注操作动作字段;
判断所述关注操作类型字段和所述关注操作动作字段的字段值是否匹配所述操作类型和所述操作动作,以获取匹配所述操作类型和所述操作动作的拦截能力对象。
3.根据权利要求2所述的前端操作拦截处理方法,其特征在于,当匹配的所述拦截能力对象具有多个时,所述通过所述插件对所述前端操作请求进行拦截处理的步骤包括:
根据所述前端操作请求获取待操作数据,将所述操作类型、所述操作动作以及所述待操作数据发送至多个插件,接收多个插件的初始处理结果,将多个初始处理结果进行合并后得到所述处理结果。
4.根据权利要求3所述的前端操作拦截处理方法,其特征在于,在所述将所述操作类型、所述操作动作以及所述待操作数据发送至多个插件的步骤之后,所述方法还包括:
获取各插件基于所述操作类型、所述操作动作以及所述待操作数据生成的预处理信息;
基于所述预处理信息判断各所述插件是否就绪,以基于就绪的插件对所述前端操作请求进行拦截处理。
5.根据权利要求1至4任一项所述的前端操作拦截处理方法,其特征在于,当所述关注操作类型字段和所述关注操作动作字段的字段值为空时,所述方法还包括:
获取所述关注操作类型字段和所述关注操作动作字段的字段值为空的拦截能力对象,将其作为与所述操作类型和所述操作动作匹配的拦截能力对象。
6.根据权利要求1至4任一项所述的前端操作拦截处理方法,其特征在于,所述根据所述前端操作请求获取操作类型和操作动作的步骤包括:
读取所述前端操作请求的请求信息,解析所述请求信息得到所述操作类型和所述操作动作;或
根据所述前端操作请求调用GraphQL接口,读取所述GraphQL接口的接口参数,进行接口参数解析得到所述操作类型和所述操作动作。
7.根据权利要求1至4任一项所述的前端操作拦截处理方法,其特征在于,在所述基于所述拦截能力列表字段的字段值创建至少一个拦截能力对象的步骤之前,所述方法还包括:
获取多个插件的配置文件,从各所述配置文件中获取对应的插件的关注操作类型字段和关注操作动作字段的字段值;
基于从所述配置文件中获取的多个字段值生成与所述拦截能力列表字段对应的拦截能力列表。
8.一种前端操作拦截处理装置,其特征在于,包括:
接收模块,用于接收前端操作请求,根据所述前端操作请求获取操作类型和操作动作;
处理模块,用于基于所述前端操作请求创建拦截能力处理器对象,并基于所述拦截能力处理器对象创建至少一个拦截能力对象,判断是否存在与所述操作类型和所述操作动作匹配的拦截能力对象,若包含则基于所述拦截能力处理器对象和匹配的拦截能力对象调用相应的插件,通过所述插件对所述前端操作请求进行拦截处理,否则直接对所述前端操作请求进行处理;
更新反馈模块,用于根据所述前端操作请求的处理结果更新数据库,并向前端反馈所述处理结果。
9.一种计算机设备,包括存储器和处理器,所述存储器中存储有计算机程序,所述处理器执行所述计算机程序时实现如权利要求1至7中任一项所述的前端操作拦截处理方法的步骤。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1至7中任一项所述的前端操作拦截处理方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310004758.1A CN116303486A (zh) | 2023-01-03 | 2023-01-03 | 前端操作拦截处理方法、装置、计算机设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310004758.1A CN116303486A (zh) | 2023-01-03 | 2023-01-03 | 前端操作拦截处理方法、装置、计算机设备及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN116303486A true CN116303486A (zh) | 2023-06-23 |
Family
ID=86824724
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202310004758.1A Pending CN116303486A (zh) | 2023-01-03 | 2023-01-03 | 前端操作拦截处理方法、装置、计算机设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN116303486A (zh) |
-
2023
- 2023-01-03 CN CN202310004758.1A patent/CN116303486A/zh active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110636106B (zh) | 信息推送方法、装置、计算机设备和存储介质 | |
CN111782304B (zh) | 分页加载数据逻辑控制方法、装置、计算机设备及介质 | |
CN113536185A (zh) | 应用页面的加载方法、存储介质、及其相关设备 | |
US20160162984A1 (en) | Processing unstructured messages | |
CN112825096A (zh) | 一种数据脱敏方法和装置 | |
CN110399131B (zh) | 提高应用程序稳定性的方法、装置、计算机设备 | |
CN106095886B (zh) | 一种数据处理方法及其装置 | |
CN116112457A (zh) | 消息通知的方法、装置、计算机设备及存储介质 | |
CN111475388A (zh) | 数据推送的测试方法、装置、计算机设备及存储介质 | |
CN116661936A (zh) | 页面数据的处理方法、装置、计算机设备及存储介质 | |
CN116303486A (zh) | 前端操作拦截处理方法、装置、计算机设备及存储介质 | |
CN113590447B (zh) | 埋点处理方法和装置 | |
CN114968822A (zh) | 接口测试方法、装置、计算机设备及存储介质 | |
WO2021248310A1 (zh) | 服务调用信息的获取方法、装置和服务的漏洞测试方法 | |
CN114363839A (zh) | 一种诈骗数据的预警方法、装置、设备及存储介质 | |
CN113448578A (zh) | 页面数据处理方法、处理系统、电子设备和可读存储介质 | |
CN110554942A (zh) | 一种监控代码执行的方法和装置 | |
CN116467145A (zh) | 页面性能数据采集方法、装置、计算机设备及存储介质 | |
CN114996557B (zh) | 服务稳定性确定方法、装置、设备以及存储介质 | |
CN116644425B (zh) | 基于Javaagent的Web漏洞即时阻断方法、装置、设备和存储介质 | |
CN115756630A (zh) | 插件处理方法、装置、计算机设备及存储介质 | |
CN112597067B (zh) | 一种测试方法、系统、电子设备及介质 | |
CN114218191A (zh) | 系统功能迁移方法、装置、计算机设备及存储介质 | |
CN116382678A (zh) | 一种基于iframe的页面构建方法及装置 | |
CN117271321A (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 |