CN107635001A - Web脚本异常处理方法和装置 - Google Patents

Web脚本异常处理方法和装置 Download PDF

Info

Publication number
CN107635001A
CN107635001A CN201710849807.6A CN201710849807A CN107635001A CN 107635001 A CN107635001 A CN 107635001A CN 201710849807 A CN201710849807 A CN 201710849807A CN 107635001 A CN107635001 A CN 107635001A
Authority
CN
China
Prior art keywords
exception
abnormal
anomalous event
rewriting
logic
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
Application number
CN201710849807.6A
Other languages
English (en)
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 Jingdong Century Trading Co Ltd
Beijing Jingdong Shangke Information Technology Co Ltd
Original Assignee
Beijing Jingdong Century Trading Co Ltd
Beijing Jingdong Shangke Information Technology 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 Jingdong Century Trading Co Ltd, Beijing Jingdong Shangke Information Technology Co Ltd filed Critical Beijing Jingdong Century Trading Co Ltd
Priority to CN201710849807.6A priority Critical patent/CN107635001A/zh
Publication of CN107635001A publication Critical patent/CN107635001A/zh
Pending legal-status Critical Current

Links

Landscapes

  • Debugging And Monitoring (AREA)

Abstract

本发明实施例公开了一种Web脚本异常处理方法和装置,涉及计算机技术领域。其中,该方法包括:拦截Web脚本中的异常事件处理器方法,并重写所述异常事件处理器方法,以根据重写的异常事件处理器方法对异常进行捕获及处理;拦截Web脚本中的回调方法,并重写所述回调方法;在重写的回调方法中注入异常捕获处理逻辑,以根据所述异常捕获处理逻辑对异常进行捕获及处理。本发明通过以上步骤,能够高度分离异常捕获代码逻辑与业务代码逻辑,有效解决异常捕获代码逻辑对业务代码逻辑的阻塞问题,提高Web脚本异常处理的可靠性。

Description

Web脚本异常处理方法和装置
技术领域
本发明涉及计算机技术领域,尤其涉及一种Web脚本异常处理方法和装置。
背景技术
随着Web(全球广域网,也称万维网)技术的发展,基于前端的交互体验越来越受到重视。由于很多以往通过后端实现的业务逻辑都转到了前端,使得前端业务逻辑越来越复杂,前端Web页面的异常量也相应地增加,进而导致前端页面的交互体验不友好。
在现有技术中,针对前端页面的异常捕获,其实并没有一套系统的、行之有效的解决方案。在实现本发明过程中,发明人发现现有技术中至少存在如下问题:现有的异常捕获代码逻辑与业务代码逻辑高度耦合,不仅不利于业务代码逻辑的扩展,而且容易造成业务代码逻辑阻塞,同时维护升级困难。
发明内容
有鉴于此,本发明实施例提供一种Web脚本异常处理方法和装置,以能够高度分离异常捕获代码逻辑与业务代码逻辑,有效解决异常捕获代码逻辑对业务代码逻辑的阻塞问题。
为实现上述目的,根据本发明实施例的一个方面,提供了一种Web脚本异常处理方法。
本发明实施例的Web脚本异常处理方法包括:拦截Web脚本中的异常事件处理器方法,并重写所述异常事件处理器方法,以根据重写的异常事件处理器方法对异常进行捕获及处理;劫持Web脚本中的回调方法,并重写所述回调方法;在重写的回调方法中注入异常捕获处理逻辑,以根据所述异常捕获处理逻辑对异常进行捕获及处理。
可选地,根据重写的异常事件处理器方法对异常进行捕获及处理,和/或,根据所述异常捕获处理逻辑对异常进行捕获及处理,包括:将捕获的异常进行自动上报。
可选地,将捕获的异常进行自动上报的步骤包括:将表示所述捕获的异常的字符串拼接至上报接口的URL中;创建图像对象,并将拼接有所述字符串的URL赋值给所述图像对象的地址属性。
可选地,所述方法还包括:将所述Web脚本中的异常事件处理器方法追加至所述重写的异常事件处理器方法的尾部;以及,将所述Web脚本中的回调方法追加至所述重写的回调方法的尾部。
可选地,所述异常事件处理器方法包括:onerror事件处理器方法;所述异常捕获处理逻辑包括:try catch异常捕获处理逻辑。
为实现上述目的,根据本发明实施例的另一方面,提供了一种Web脚本异常处理装置。
本发明实施例的Web脚本异常处理装置包括:第一异常处理模块,用于拦截Web脚本中的异常事件处理器方法,并重写所述异常事件处理器方法,以根据重写的异常事件处理器方法对异常进行捕获及处理;第二异常处理模块,用于拦截Web脚本中的回调方法,并重写所述回调方法;还用于在重写的回调方法中注入异常捕获处理逻辑,以根据所述异常捕获处理逻辑对异常进行捕获及处理。
可选地,所述第一异常处理模块根据重写的异常事件处理器方法对异常进行捕获及处理,和/或,所述第二异常处理模块根据所述异常捕获处理逻辑对异常进行捕获及处理,包括:将捕获的异常进行自动上报。
可选地,所述第一异常处理模块,和/或,所述第二异常处理模块将捕获的异常进行自动上报包括:将表示所述捕获的异常的字符串拼接至上报接口的URL中;创建图像对象,并将拼接有所述字符串的URL赋值给所述图像对象的地址属性。
可选地,第一异常处理模块还用于:将所述Web脚本中的异常事件处理器方法追加至所述重写的异常事件处理器方法的尾部;第二异常处理模块还用于:将所述Web脚本中的回调方法追加至所述重写的回调方法的尾部。
可选地,所述异常事件处理器方法包括:onerror事件处理器方法;所述异常捕获处理逻辑包括:try catch异常捕获处理逻辑。
为实现上述目的,根据本发明实施例的再一个方面,提供了一种终端设备。
本发明实施例的终端设备,包括:一个或多个处理器;以及,存储装置,用于存储一个或多个程序;当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现本发明实施例的Web脚本异常处理方法。
为实现上述目的,根据本发明实施例的又一个方面,提供了一种计算机可读介质。
本发明实施例的计算机可读介质,其上存储有计算机程序,所述程序被处理器执行时实现本发明实施例的Web脚本异常处理方法。
上述发明中的一个实施例具有如下优点或有益效果:在本发明实施例中,通过拦截Web脚本中的异常事件处理器方法以及回调方法,并通过重写异常事件处理器方法以及重写回调方法等步骤,实现了异常捕获处理代码与业务代码的高度分离,有效解决了异常捕获代码逻辑对业务代码逻辑的阻塞问题,提高了Web脚本异常处理方法的可靠性。同时,通过结合两种异常捕获处理方式,提高了异常捕获处理的覆盖率和处理效率。
上述的非惯用的可选方式所具有的进一步效果将在下文中结合具体实施方式加以说明。
附图说明
附图用于更好地理解本发明,不构成对本发明的不当限定。其中:
图1是根据本发明实施例的Web脚本异常处理方法的主要流程示意图;
图2是根据本发明实施例的Web脚本异常处理装置的主要模块示意图;
图3是本发明实施例可以应用于其中的示例性系统架构图;
图4是适于用来实现本发明实施例的终端设备的计算机系统的结构示意图。
具体实施方式
以下结合附图对本发明的示范性实施例做出说明,其中包括本发明实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本发明的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
需要指出的是,在不冲突的情况下,本发明中的实施例以及实施例中的特征可以相互组合。
在详细介绍本发明实施例之前,首先对本发明实施例涉及的部分技术术语进行说明。
Web:即全球广域网,也称为万维网。它是一种基于超文本和HTTP的、全球性的、动态交互的、跨平台的分布式图形信息系统。它是建立在因特网(Internet)上的一种网络服务,为浏览者在因特网上查找和浏览信息提供了图形化的、易于访问的直观界面,其中的文档及超级链接将因特网上的信息节点组织成一个互为关联的网状结构。
URL:统一资源定位符。它是对可以从互联网上得到的资源的位置和访问方法的一种简洁的表示,是互联网上标准资源的地址。
Javascript:一种直译式脚本语言。它是一种动态类型、弱类型、基于原型的语言,内置支持类型。它的解释器被称为Javascript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在HTML(标准通用标记语言下的一个应用)网页上使用,用来给HTML网页增加动态功能。
onerror事件:浏览器在文档或图像加载过程中发生错误时被触发的计算机事件。
setTimeout方法:用于在指定的毫秒数后调用函数或计算表达式。
setInterval方法:是实现定时调用的函数,可按照指定的周期来调用函数或计算表达式。
$.Ajax方法:用于通过HTTP请求加载远程数据。
图1是根据本发明实施例的Web脚本异常处理方法的主要流程示意图。如图1所示,本发明实施例的Web脚本异常处理方法主要包括以下步骤:
步骤S101、拦截Web脚本中的异常事件处理器方法,并重写新的异常事件处理器方法,以根据重写的异常事件处理器方法对异常进行捕获及处理。
示例性的,所述Web脚本为Javascript脚本,所述异常事件处理器方法为onerror事件处理器方法。在该示例中,拦截Web脚本中的异常事件处理器方法具体为:将系统默认的onerror事件处理器方法保存至一个中间变量中,以钩住(或称为“挂起”)系统默认的onerror事件处理器方法;然后,重写onerror事件处理器方法,以根据重写的onerror事件处理器方法捕获并处理异常。
在一可选实现方式中,根据重写的异常事件处理器方法对异常进行捕获及处理包括:将捕获的异常进行自动上报。在具体实施时,可采用图片加载的方式实现异常的自动上报,包括:将捕获的异常处理成字符串的形式,并将表示所述捕获的异常的字符串拼接至上报接口的URL中;创建图像对象,并将拼接有所述字符串的URL赋值给所述图像对象的地址属性(src属性)。通过采用图片加载的方式实现异常的自动上报,不仅避免了异常上报对业务代码逻辑的阻塞,而且操作简单、浏览器兼容性好。
可理解的是,在具体实施时,本领域技术人员还可采用其他实现异常自动上报的方式。比如,可通过创建隐藏式的网页标签(iframe)的方式实现异常自动上报。
在一可选实现方式中,步骤S101还包括:将所述Web脚本中的异常事件处理器方法追加至所述重写的异常事件处理器方法的尾部。例如,可以先通过apply方法将保存在中间变量中的系统默认的onerror事件处理器方法的作用域修改为当前上下文,再在重写的onerror事件处理器方法的尾部调用系统默认的onerror事件处理器方法。通过以上步骤,能够保证重写的onerror事件处理器方法不破坏系统默认的onerror事件处理器方法,从而不影响系统默认的onerror事件处理器方法被其他系统或模块调用。
步骤S102、拦截Web脚本中的回调方法,并重写所述回调方法;在重写的回调方法中注入异常捕获处理逻辑,以根据所述异常捕获处理逻辑对异常进行捕获及处理。
在本发明实施例中,考虑到异常事件处理器方法在跨域或异步回调等复杂异常情况下不能获得详细的异常信息。故而,对于跨域或异步回调等复杂异常情况,可通过步骤S102来进行异常捕获及处理。
示例性的,所述异常捕获处理逻辑为try catch异常捕获处理逻辑。在该示例中,步骤S102的一种具体实施方式为:在调用所述异步入口方法时,提取所述异步入口方法的参数列表中的回调方法;然后,将系统默认的回调方法保存至中间变量中,以钩住(或称为“挂起”)所述回调方法;接下来,重写所述回调方法。并且,在重写的回调方法中注入trycatch异常捕获处理逻辑,以根据try catch异常捕获处理逻辑对异常进行捕获、处理。在具体实施时,所述异步入口方法可以包括:系统方法中的setTimeout方法、setInterval方法,第三方使用较多的Jquery框架里的$.event.add方法、$.event.remove方法和$.Ajax方法,以及模块化开发中的require方法、define方法等等。
在一可选实现方式中,根据所述异常捕获处理逻辑对异常进行捕获及处理包括:将捕获的异常进行自动上报。具体实施时,可通过图片加载的方式实现异常的自动上报,包括:将捕获的异常处理成字符串的形式,并将表示所述捕获的异常的字符串拼接至上报接口的URL中;创建图像对象,并将拼接有所述字符串的URL赋值给所述图像对象的地址属性(src属性)。通过采用图片加载的方式实现异常的自动上报,不仅避免了异常上报对业务代码逻辑的阻塞,而且操作简单、浏览器兼容性好。
可理解的是,在具体实施时,本领域技术人员还可采用其他实现异常自动上报的方式。比如,可通过创建隐藏式的网页标签(iframe)的方式实现异常自动上报。
在一可选实现方式中,步骤S102还包括:将所述Web脚本中的回调方法追加至所述新的回调方法的尾部。通过以上步骤,能够保证重写的异步回调方法不破坏系统默认的异步回调方法,从而不影响系统默认的异步回调方法被其他系统或模块调用。
需要指出的是,在本发明实施例中,步骤S101与步骤S102针对的异常捕获处理场景不同,两个步骤并没有执行顺序的限制。
在本发明实施例中,巧妙运用了Web脚本“劫持”的策略,具体包括:拦截Web脚本中的异常事件处理器方法以及回调方法,并重写所述异常事件处理器方法以及重写回调方法等步骤。通过以上步骤,实现了异常捕获处理代码与业务代码的高度分离,有效解决了异常捕获代码逻辑对业务代码逻辑的阻塞问题,提高了异常处理方法的可靠性。另外,通过结合“重写的异常事件处理器方法”与“在重写的回调方法中注入的异常捕获处理逻辑”这两种异常捕获处理方式,不仅能够有效覆盖网页上绝大部分的异常情况,而且能够提高异常捕获处理的效率。
图2是根据本发明实施例的Web脚本异常处理装置的主要模块示意图。如图2所示,本发明实施例的Web脚本异常处理装置200包括:第一异常处理模块201、第二异常处理模块202。
第一异常处理模块201,用于拦截Web脚本中的异常事件处理器方法,并重写所述异常事件处理器方法,以根据重写的异常事件处理器方法对异常进行捕获及处理。
示例性的,所述Web脚本为Javascript脚本,第一异常处理模块201拦截的所述异常事件处理器方法为onerror事件处理器方法。在该示例中,第一异常处理模块201拦截Javascript脚本中的onerror事件处理器方法具体为:将Javascript脚本中的onerror事件处理器方法(即系统默认的onerror事件处理器方法)保存至一个中间变量中,以钩住(或称为“挂起”)Javascript脚本中的onerror事件处理器方法。然后,第一异常处理模块201重写onerror事件处理器方法,并在重写的onerror事件处理器方法中捕获并处理异常。
在一可选实现方式中,第一异常处理模块201根据重写的异常事件处理器方法对异常进行捕获及处理包括:将捕获的异常进行自动上报。具体实施时,第一异常处理模块201可采用图片加载的方式实现异常的自动上报,包括:将捕获的异常处理成字符串的形式,并将表示所述捕获的异常的字符串拼接至上报接口的URL中;创建图像对象,并将拼接有所述字符串的URL赋值给所述图像对象的地址属性(src属性)。第一异常处理模块201通过采用图片加载的方式实现异常的自动上报,不仅避免了异常上报对业务代码逻辑的阻塞,而且采用这种异常上报方式操作简单、浏览器兼容性好。
可理解的是,在具体实施时,第一异常处理模块201还可采用其他实现异常自动上报的方式。比如,第一异常处理模块201可通过创建隐藏式的网页标签(iframe)的方式实现异常自动上报。
在一可选实现方式中,第一异常处理模块201还用于:将所述Web脚本中的异常事件处理器方法追加至所述重写的异常事件处理器方法的尾部。例如,可以先通过apply方法将保存在中间变量中的系统默认的onerror事件处理器方法的作用域修改为当前上下文,再在重写的onerror事件处理器方法的尾部调用系统默认的onerror事件处理器方法。通过以上操作,能够保证重写的onerror事件处理器方法不破坏系统默认的onerror事件处理器方法,从而不影响系统默认的onerror事件处理器方法被其他系统或模块调用。
第二异常处理模块202,用于拦截Web脚本中的回调方法,并重写所述回调方法;还用于在重写的回调方法中注入异常捕获处理逻辑,以根据所述异常捕获处理逻辑对异常进行捕获及处理。
示例性的,第二异常处理模块202注入的所述异常捕获处理逻辑为try catch异常捕获处理逻辑。在该示例中,在触发调用异步入口方法的事件后,第二异常处理模块202可以先从调用的异步入口方法的参数列表中提取回调方法,并将所述回调方法保存至中间变量中,以挂起系统默认的回调方法。然后,第二异常处理模块202重写所述回调方法。并且,第二异常处理模块202在重写的回调方法中注入try catch异常捕获处理逻辑,以根据trycatch异常捕获处理逻辑对异常进行捕获及处理。
在一可选实现方式中,第二异常处理模块202根据所述异常捕获处理逻辑对异常进行捕获及处理,包括:将捕获的异常进行自动上报。具体实施时,第二异常处理模块202可采用图片加载的方式实现异常的自动上报,包括:将捕获的异常处理成字符串的形式,并将表示所述捕获的异常的字符串拼接至上报接口的URL中;创建图像对象,并将拼接有所述字符串的URL赋值给所述图像对象的地址属性(src属性)。第二异常处理模块202通过采用图片加载的方式实现异常的自动上报,不仅避免了异常上报对业务代码逻辑的阻塞,而且操作简单、浏览器兼容性好。
可理解的是,在具体实施时,第二异常处理模块202还可采用其他实现异常自动上报的方式。比如,第二异常处理模块202可通过创建隐藏式的网页标签(iframe)的方式实现异常自动上报。
在一可选实现方式中,第二异常处理模块202还用于:将所述Web脚本中的回调方法(即系统默认的异步回调方法)追加至所述重写的回调方法的尾部。通过执行以上操作,能够保证重写的异步回调方法不破坏系统默认的异步回调方法,从而不影响系统默认的异步回调方法被其他系统或模块调用。
在本发明实施例中,通过设置第一异常处理模块、第二异常处理模块,能够实现异常捕获处理代码与业务代码的高度分离,有效解决异常捕获代码逻辑对业务代码逻辑的阻塞问题,提高异常捕获处理的可靠性。同时,本发明的Web脚本异常处理装置可以独立成模块组件,以便被重复使用于多个业务场景中,实现Web脚本异常处理装置的高复用低耦合。另外,通过结合第一异常处理模块与第二异常处理模块,不仅能够有效覆盖网页上绝大部分的异常情况,而且能够提高异常捕获处理的效率。
图3示出了可以应用本发明实施例的Web脚本异常处理方法或Web脚本异常处理装置的示例性系统架构300。
如图3所示,系统架构300可以包括终端设备301、302、303,网络304和服务器305。网络304用以在终端设备301、302、303和服务器305之间提供通信链路的介质。网络304可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备301、302、303通过网络304与服务器305交互,以接收或发送消息等。终端设备301、302、303上可以安装有各种通讯客户端应用,例如购物类应用、网页浏览器应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等。
终端设备301、302、303可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。
服务器305可以是提供各种服务的服务器,例如对用户利用终端设备301、302、303所浏览的购物类网站提供支持的后台管理服务器。后台管理服务器可以对接收到的产品信息查询请求等数据进行分析等处理,并将处理结果反馈给终端设备。
需要说明的是,本发明实施例所提供的Web脚本异常处理方法一般由终端设备执行,相应地,Web脚本异常处理装置一般设置于终端设备中。
应该理解,图3中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
图4示出了适于用来实现本发明实施例的终端设备的计算机系统400的结构示意图。图4示出的终端设备仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图4所示,计算机系统400包括中央处理单元(CPU)401,其可以根据存储在只读存储器(ROM)402中的程序或者从存储部分408加载到随机访问存储器(RAM)403中的程序而执行各种适当的动作和处理。在RAM 403中,还存储有系统400操作所需的各种程序和数据。CPU 401、ROM 402以及RAM 403通过总线404彼此相连。输入/输出(I/O)接口405也连接至总线404。
以下部件连接至I/O接口405:包括键盘、鼠标等的输入部分406;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分407;包括硬盘等的存储部分408;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分409。通信部分409经由诸如因特网的网络执行通信处理。驱动器410也根据需要连接至I/O接口405。可拆卸介质411,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器410上,以便于从其上读出的计算机程序根据需要被安装入存储部分408。
特别地,根据本发明公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本发明公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分409从网络上被下载和安装,和/或从可拆卸介质411被安装。在该计算机程序被中央处理单元(CPU)401执行时,执行本发明的系统中限定的上述功能。
需要说明的是,本发明所示的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本发明中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本发明中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
附图中的流程图和框图,图示了按照本发明各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本发明实施例中所涉及到的模块可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的模块也可以设置在处理器中,例如,可以描述为:一种处理器包括第一异常处理模块、第二异常处理模块。其中,这些模块的名称在某种情况下并不构成对该模块本身的限定,例如,第一异常处理模块还可以被描述为“用于对异常进行捕获及处理的模块”。
作为另一方面,本发明还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的设备中所包含的;也可以是单独存在,而未装配入该设备中。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被一个该设备执行时,使得该设备执行以下流程:拦截Web脚本中的异常事件处理器方法,并重写所述异常事件处理器方法,以根据重写的异常事件处理器方法对异常进行捕获及处理;拦截Web脚本中的回调方法,并重写所述回调方法;在重写的回调方法中注入异常捕获处理逻辑,以根据所述异常捕获处理逻辑对异常进行捕获及处理。
上述具体实施方式,并不构成对本发明保护范围的限制。本领域技术人员应该明白的是,取决于设计要求和其他因素,可以发生各种各样的修改、组合、子组合和替代。任何在本发明的精神和原则之内所作的修改、等同替换和改进等,均应包含在本发明保护范围之内。

Claims (12)

1.一种Web脚本异常处理方法,其特征在于,包括:
拦截Web脚本中的异常事件处理器方法,并重写所述异常事件处理器方法,以根据重写的异常事件处理器方法对异常进行捕获及处理;
拦截Web脚本中的回调方法,并重写所述回调方法;在重写的回调方法中注入异常捕获处理逻辑,以根据所述异常捕获处理逻辑对异常进行捕获及处理。
2.根据权利要求1所述的方法,其特征在于,根据重写的异常事件处理器方法对异常进行捕获及处理,和/或,根据所述异常捕获处理逻辑对异常进行捕获及处理,包括:将捕获的异常进行自动上报。
3.根据权利要求2所述的方法,其特征在于,将捕获的异常进行自动上报包括:
将表示所述捕获的异常的字符串拼接至上报接口的URL中;创建图像对象,并将拼接有所述字符串的URL赋值给所述图像对象的地址属性。
4.根据权利要求1所述的方法,其特征在于,所述方法还包括:
将所述Web脚本中的异常事件处理器方法追加至所述重写的异常事件处理器方法的尾部;以及,将所述Web脚本中的回调方法追加至所述重写的回调方法的尾部。
5.根据权利要求1所述的方法,其特征在于,所述异常事件处理器方法包括:onerror事件处理器方法;所述异常捕获处理逻辑包括:try catch异常捕获处理逻辑。
6.一种Web脚本异常处理装置,其特征在于,所述装置包括:
第一异常处理模块,用于拦截Web脚本中的异常事件处理器方法,并重写所述异常事件处理器方法,以根据重写的异常事件处理器方法对异常进行捕获及处理;
第二异常处理模块,用于拦截Web脚本中的回调方法,并重写所述回调方法;还用于在重写的回调方法中注入异常捕获处理逻辑,以根据所述异常捕获处理逻辑对异常进行捕获及处理。
7.根据权利要求6所述的装置,其特征在于,所述第一异常处理模块根据重写的异常事件处理器方法对异常进行捕获及处理,和/或,所述第二异常处理模块根据所述异常捕获处理逻辑对异常进行捕获及处理,包括:将捕获的异常进行自动上报。
8.根据权利要求7所述的装置,其特征在于,所述第一异常处理模块,和/或,所述第二异常处理模块将捕获的异常进行自动上报包括:
将表示所述捕获的异常的字符串拼接至上报接口的URL中;创建图像对象,并将拼接有所述字符串的URL赋值给所述图像对象的地址属性。
9.根据权利要求6所述的装置,其特征在于,第一异常处理模块还用于:将所述Web脚本中的异常事件处理器方法追加至所述重写的异常事件处理器方法的尾部;第二异常处理模块还用于:将所述Web脚本中的回调方法追加至所述重写的回调方法的尾部。
10.根据权利要求6所述的装置,其特征在于,所述异常事件处理器方法包括:onerror事件处理器方法;所述异常捕获处理逻辑包括:try catch异常捕获处理逻辑。
11.一种终端设备,其特征在于,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1至5中任一所述的方法。
12.一种计算机可读介质,其上存储有计算机程序,其特征在于,所述程序被处理器执行时实现如权利要求1至5中任一所述的方法。
CN201710849807.6A 2017-09-20 2017-09-20 Web脚本异常处理方法和装置 Pending CN107635001A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201710849807.6A CN107635001A (zh) 2017-09-20 2017-09-20 Web脚本异常处理方法和装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201710849807.6A CN107635001A (zh) 2017-09-20 2017-09-20 Web脚本异常处理方法和装置

Publications (1)

Publication Number Publication Date
CN107635001A true CN107635001A (zh) 2018-01-26

Family

ID=61102008

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201710849807.6A Pending CN107635001A (zh) 2017-09-20 2017-09-20 Web脚本异常处理方法和装置

Country Status (1)

Country Link
CN (1) CN107635001A (zh)

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110489252A (zh) * 2018-05-15 2019-11-22 腾讯科技(深圳)有限公司 图片处理方法、装置、计算机可读存储介质和计算机设备
CN111142982A (zh) * 2018-11-02 2020-05-12 鸿合科技股份有限公司 一种事件执行方法及装置、电子设备
CN111274574A (zh) * 2020-01-16 2020-06-12 恩亿科(北京)数据科技有限公司 网页事件防抖方法、装置、服务器及计算机可读存储介质
CN112887162A (zh) * 2019-11-29 2021-06-01 北京百度网讯科技有限公司 用于检测异常的方法及装置
CN112948726A (zh) * 2021-03-29 2021-06-11 建信金融科技有限责任公司 一种处理异常信息的方法、装置和系统
CN113268689A (zh) * 2021-06-01 2021-08-17 广州欢网科技有限责任公司 网页加载异常数据处理方法及装置

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103309761A (zh) * 2013-05-31 2013-09-18 深圳创维数字技术股份有限公司 一种基于在线服务的自动纠错的方法和系统
CN106897215A (zh) * 2017-01-20 2017-06-27 华南理工大学 一种基于WebView网页加载性能及用户行为流数据采集的方法

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103309761A (zh) * 2013-05-31 2013-09-18 深圳创维数字技术股份有限公司 一种基于在线服务的自动纠错的方法和系统
CN106897215A (zh) * 2017-01-20 2017-06-27 华南理工大学 一种基于WebView网页加载性能及用户行为流数据采集的方法

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
OUVEN: "前端一站式异常解决方案", 《极限前端,极限前端社区,OUVENZHANG的博客》 *
冰凌哒雪花: "前端异常采集", 《博客园》 *

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110489252A (zh) * 2018-05-15 2019-11-22 腾讯科技(深圳)有限公司 图片处理方法、装置、计算机可读存储介质和计算机设备
CN110489252B (zh) * 2018-05-15 2022-04-22 腾讯科技(深圳)有限公司 图片处理方法、装置、计算机可读存储介质和计算机设备
CN111142982A (zh) * 2018-11-02 2020-05-12 鸿合科技股份有限公司 一种事件执行方法及装置、电子设备
CN112887162A (zh) * 2019-11-29 2021-06-01 北京百度网讯科技有限公司 用于检测异常的方法及装置
CN112887162B (zh) * 2019-11-29 2022-03-29 北京百度网讯科技有限公司 用于检测异常的方法及装置
CN111274574A (zh) * 2020-01-16 2020-06-12 恩亿科(北京)数据科技有限公司 网页事件防抖方法、装置、服务器及计算机可读存储介质
CN112948726A (zh) * 2021-03-29 2021-06-11 建信金融科技有限责任公司 一种处理异常信息的方法、装置和系统
CN113268689A (zh) * 2021-06-01 2021-08-17 广州欢网科技有限责任公司 网页加载异常数据处理方法及装置

Similar Documents

Publication Publication Date Title
CN107635001A (zh) Web脚本异常处理方法和装置
CN108052334B (zh) 页面跳转方法、装置、计算机设备和存储介质
US10003671B2 (en) Capturing and replaying application sessions using resource files
US10725625B2 (en) Displaying webpage information of parent tab associated with new child tab on graphical user interface
CN107357914B (zh) 信息处理方法和装置
US20150058407A1 (en) Systems, methods, and apparatuses for implementing the simultaneous display of multiple browser client cursors at each browser client common to a shared browsing session
WO2016173200A1 (zh) 用于检测恶意网址的方法和系统
CN107844324A (zh) 客户端页面跳转处理方法和装置
CN104426985B (zh) 显示网页的方法、装置及系统
CN107766509A (zh) 一种网页静态备份的方法和装置
CN109829121B (zh) 一种点击行为数据上报的方法和装置
US20150222664A1 (en) Conflict resolution in extension induced modifications to web requests and web page content
CN106503111B (zh) 网页转码方法、装置及客户终端
CN108846286A (zh) 跨站脚本漏洞检测方法及装置
CN107329978A (zh) 多平台融合的路由方法和装置
CN107634947A (zh) 限制恶意登录或注册的方法和装置
CN110598135A (zh) 网络请求处理方法、装置、计算机可读介质及电子设备
CN109582317A (zh) 用于调试寄宿应用的方法和装置
CN113076294A (zh) 一种信息分享方法和装置
CN112015383A (zh) 一种登录方法和装置
CN105119764B (zh) 用于流量监控的方法和装置
US11902387B2 (en) Apparatus and methods for real-time rendering of zero-byte customized software on a client station
CN110347945A (zh) 获取页面的数据的方法和装置
CN107346309A (zh) 一种网络应用中静态资源的处理方法及装置
CN113726855B (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: 20180126

RJ01 Rejection of invention patent application after publication