具体实施方式
下面将结合本发明实施例中附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。通常在此处附图中描述和示出的本发明实施例的组件可以以各种不同的配置来布置和设计。因此,以下对在附图中提供的本发明的实施例的详细描述并非旨在限制要求保护的本发明的范围,而是仅仅表示本发明的选定实施例。基于本发明的实施例,本领域技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。
应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。同时,在本发明的描述中,术语“第一”、“第二”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
本发明实施例所提供的应用程序错误定位方法及装置可应用于如图1所示的应用环境中。如图1所示,用户终端100、服务器400位于网络300中,网络300包括无线网络或有线网络,通过网络300,用户终端100与服务器400进行数据交互。服务器400可以是一个服务器400,也可以是多个执行不同任务的服务器400。
于本发明实施例中,用户终端100优选为移动终端设备,例如可以包括智能手机、平板电脑、电子书阅读器、膝上型便携计算机、车载电脑、穿戴式移动终端等等。该用户终端100中安装ReactNative客户端500,与服务器400相对应,为用户提供服务。
图2示出本发明较佳实施例提供的用户终端100的方框示意图。所述用户终端100可以是平板电脑、智能手机、个人数字助理(personal digital assistant,PDA)等。所述用户终端100包括应用程序错误定位装置200、存储器101、存储控制器102、处理器103、外设接口104、通信单元105及输入输出单元106。
所述存储器101、存储控制器102、处理器103、外设接口104、通信单元105、输入输出单元106各元件相互之间直接或间接地电性连接,以实现数据的传输或交互。例如,这些元件相互之间可通过一条或多条通讯总线或信号线实现电性连接。所述应用程序错误定位装置200包括至少一个可以软件或固件(firmware)的形式存储于所述存储器101中或固化在所述用户终端100的操作系统(operating system,OS)中的软件功能模块。所述处理器103用于执行存储器101中存储的可执行模块,例如所述应用程序错误定位装置200包括的软件功能模块或计算机程序。
其中,存储器101可以是,但不限于,随机存取存储器(Random Access Memory,RAM),只读存储器(Read Only Memory,ROM),可编程只读存储器(Programmable Read-OnlyMemory,PROM),可擦除只读存储器(Erasable Programmable Read-Only Memory,EPROM),电可擦除只读存储器(Electric Erasable Programmable Read-Only Memory,EEPROM)等。其中,存储器101用于存储程序,所述处理器103在接收到执行指令后,执行所述程序,本发明任一实施例揭示的流过程定义的服务器所执行的方法可以应用于处理器103中,或者由处理器103实现。
处理器103可能是一种集成电路芯片,具有信号的处理能力。上述的处理器103可以是通用处理器,包括中央处理器(Central Processing Unit,简称CPU)、网络处理器(Network Processor,简称NP)等;还可以是数字信号处理器(DSP)、专用集成电路(ASIC)、现场可编程门阵列(FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本发明实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器103也可以是任何常规的处理器103等。
所述外设接口104将各种输入/输出装置耦合至处理器103以及存储器101。在一些实施例中,外设接口104,处理器103以及存储控制器102可以在单个芯片中实现。在其他一些实例中,他们可以分别由独立的芯片实现。
通信单元105用于通过所述网络300建立用户终端100与所述服务器400之间的通信连接,并用于通过所述网络300收发数据。
输入输出单元106用于提供给用户输入数据实现用户与所述用户终端100的交互。所述输入输出单元106可以是,但不限于,鼠标和键盘等,所述键盘可以是虚拟键盘。
第一实施例
请参考图3,图3为本发明较佳实施例提供的一种应用程序错误定位方法的流程图。所述方法应用于ReactNative客户端500。应用程序错误定位方法包括以下步骤:
步骤S101,响应数据请求,生成请求信息。
在本实施例中,数据请求可以是用户终端100运行ReactNative客户端500的过程中触发的需要与服务器400之间进行通信的数据请求。可选地,可以是用户触发的数据请求。可选地,ReactNative客户端500响应用户请求,执行生成请求信息的方式可以是根据所述数据请求对应的请求参数、预设的成功回调参数及预设的失败回调参数,生成请求信息。
export function post(url,data,successCallback,failCallback){};
varfetchOptions={method:‘POST’,header:{‘Content-Type’:
‘application/x-www-form-urlencoded’},body:data};
步骤S102,将所述请求信息发送至所述服务器400,以获得所述服务器400反馈的响应结果。
在本实施例中,通过所述通信模块105将所述请求信息发送至服务器400,以获得服务器400反馈的响应结果。响应结果可以是,但不限于是,接收到服务器400根据请求信息生成的响应数据、在预定时间内未接收到服务器400的任何反馈信息或接收到服务器400反馈的预设的失败回调参数。其中,服务器400反馈的预设的失败回调参数可以是服务器400检测到数据请求存在错误后,将与错误对应的原因通过请求信息中的预设的失败回调参数反馈给ReactNative客户端500(例如,服务器400重复收到同一请求信息,则将重复收到的同一请求信息对应的错误代码放入预设的失败回调参数,并将预设的失败回调参数反馈给ReactNative客户端500)。可选地,将所述请求信息发送至所述服务器400可以通过以下代码实现:
fetch(url,fetchOptions).then(res=>
{successCallback(res)}).catch(err=>{postError(err),failCallback(err)})
步骤S103,根据所述响应结果,侦测所述数据请求失败与否。
在本实施例中,根据获得的响应结果监控出现数据请求失败的情况发生。一般而言,应用程序出现错误可以通过在与服务器400通信的过程中体现出来。因此,通过侦测数据请求失败的发生,可定位应用程序错误。可选地,执行侦测所述数据请求失败与否的方式包括当所述响应结果包括与所述数据请求对应的响应数据,则所述数据请求成功。当所述响应结果未包括与所述数据请求对应的响应数据,则所述数据请求失败。可选地,所述响应结果未包括与所述数据请求对应的响应数据的情况可以包括以下任意一种情况:在预设时间内未接收到所述服务器400反馈的所述响应数据;接收到的所述响应数据与所述数据请求不匹配;或接收到所述服务器400反馈的所述预设的失败回调参数。
步骤S104,当侦测到所述数据请求失败,生成报错请求。
在本实施例中,如果没有侦测到所述数据请求失败,则应用程序继续正常运行。如果侦测到所述数据请求失败,则执行生成报错请求。从而,在定位程序错误的同时也不影响用户的使用体验。请参考图4,步骤S104还包括以下子步骤:
子步骤S1041,根据所述数据请求失败对应的响应结果,生成错误数据。
在本实施例中,错误数据可以是错误类型数据(例如,错误代码404)以及可以概括错误发生原因的数据。可选地,生成错误数据的方式可以包括,但不限于以下几种:
当在预设时间内未接收到所述服务器400反馈的所述响应数据,生成延时错误数据。可选地,预设时间内未接收到所述服务器400反馈的所述响应数据可以是收到响应数据已超时;也可以是一直未收到响应数据。ReactNative客户端500会根据具体的情况,生成对应的延时错误数据。
当接收到的所述响应数据与所述数据请求不匹配,生成不匹配错误数据。
当接收到所述服务器400反馈的所述预设的失败回调参数,则根据所述预设的失败回调参数生成失败回调错误数据。根据所述错误回调参数获取服务器400判断的失败回调错误数据。
子步骤S1042,根据所述错误数据,生成报错请求。
在本实施例中,根据错误数据及服务器400地址生成报错请求。需要说明的是,接收报错请求的服务器400可以与跟应用程序运行时进行数据交换的服务器400可以是同一个服务器400,也可以是不同的服务器400。因此,服务器400地址为作为接收报错请求的服务器400的地址。
步骤S105,将所述报错请求发送至所述服务器400,以便定位所述应用程序的错误。
在本实施例中,根据报错请求中服务器400地址,将所述报错请求发送至服务器400。服务器400根据报错请求获得错误数据,并将错误数据存储并分析。例如,当错误数据为延时错误数据,则应用程序在网络配置部分可能存在问题;当错误数据为不匹配错误数据,则可能是请求信息或者反馈的响应数据在传输过程中遭到篡改,则网络安全可能存在问题;当错误数据为失败回调错误数据时,则可能是在ReactNative客户端500到服务器400的上行通信存在问题等。可选地,将该步骤可以通过以下代码实现:
fetch(errurl,fetchOptions)
程序管理员可以在服务器400中查询错误数据及分析结果,并根据错误数据及分析结果在下一次应用程序更新时,解决应用程序中存在的问题。提高应用程序的使用体验。
第二实施例
请参考图5,是本发明较佳实施例提供的一种应用程序错误定位装置200的功能模块示意图。所述装置运用于ReactNative客户端500。应用程序错误定位装置200包括请求生成模块201、请求发送模块202、侦测模块203、报错请求生成模块204及报错请求发送模块205。
请求生成模块201,用于响应数据请求,生成请求信息。
在本实施例中,步骤S101可以由请求生成模块201执行。可选地,请求生成模块201执行生成请求信息的方式包括根据所述数据请求对应的请求参数、预设的成功回调参数及预设的失败回调参数,生成请求信息。
请求发送模块202,用于将所述请求信息发送至所述服务器400,以获得所述服务器400反馈的响应结果。
在本实施例中,步骤S102可以由请求发送模块202执行。响应结果可以是,但不限于是,接收到服务器400根据请求信息生成的响应数据、在预定时间内未接收到服务器400的任何反馈信息或接收到服务器400反馈的预设的失败回调参数。其中,服务器400反馈的预设的失败回调参数可以是服务器400检测到数据请求存在错误后,将与错误对应的原因通过请求信息中的预设的失败回调参数反馈给ReactNative客户端500(例如,服务器400重复收到同一请求信息,则将重复收到的同一请求信息对应的错误代码放入预设的失败回调参数,并将预设的失败回调参数反馈给ReactNative客户端500)。
侦测模块203,用于根据所述响应结果,侦测所述数据请求失败与否。
在本实施例中,步骤S103可以由侦测模块203执行。可选地,执行侦测所述数据请求失败与否的方式包括当所述响应结果包括与所述数据请求对应的响应数据,则所述数据请求成功。当所述响应结果未包括与所述数据请求对应的响应数据,则所述数据请求失败。可选地,所述响应结果未包括与所述数据请求对应的响应数据的情况可以包括以下任意一种情况:在预设时间内未接收到所述服务器400反馈的所述响应数据;接收到的所述响应数据与所述数据请求不匹配;或接收到所述服务器400反馈的所述预设的失败回调参数。
报错请求生成模块204,用于当侦测到所述数据请求失败,生成报错请求。
在本实施例中,步骤S104可以由报错请求生成模块204执行。如图6所示,报错请求生成模块204包括第一生成子模块2041及第二生成子模块2042。
第一生成子模块2041,用于根据所述数据请求失败对应的响应结果,生成错误数据。例如,当在预设时间内未接收到所述服务器400反馈的所述响应数据,生成延时错误数据。当接收到的所述响应数据与所述数据请求不匹配,生成不匹配错误数据。当接收到所述服务器400反馈的所述预设的失败回调参数,则根据所述预设的失败回调参数生成失败回调错误数据。根据所述错误回调参数获取服务器400判断的失败回调错误数据。
在本实施例中,子步骤S1041可以由第一生成子模块2041执行。
第二生成子模块2042,用于根据所述错误数据,生成报错请求。可选地,根据错误数据及服务器400地址生成报错请求。
在本实施例中,子步骤S1042可以由第二生成子模块2042执行。
报错请求发送模块205,用于将所述报错请求发送至所述服务器400,以便定位所述应用程序的错误。
在本实施例中,步骤S105可以由报错请求发送模块205执行。根据报错请求中服务器400地址,将所述报错请求发送至服务器400。服务器400根据报错请求获得错误数据,并将错误数据存储并分析。例如,当错误数据为延时错误数据,则应用程序在网络配置部分可能存在问题;当错误数据为不匹配错误数据,则可能是请求信息或者反馈的响应数据在传输过程中遭到篡改,则网络安全可能存在问题;当错误数据为失败回调错误数据时,则可能是在ReactNative客户端500到服务器400的上行通信存在问题等。程序管理员可以在服务器400中查询错误数据及分析结果,并根据错误数据及分析结果在下一次应用程序更新时,解决应用程序中存在的问题。提高应用程序的使用体验。
综上所述,本发明提供的一种应用程序错误定位方法及装置。所述方法应用于与服务器通信连接的ReactNative客户端,所述方法包括:响应数据请求,生成请求信息。将所述请求信息发送至所述服务器,以获得所述服务器反馈的响应结果。根据所述响应结果,侦测所述数据请求失败与否。当侦测到所述数据请求失败,生成报错请求。将所述报错请求发送至所述服务器定位所述应用程序的错误。仅在错误发生的过程中对错误进行定位并发送给服务器,从而不影响用户对应用程序的正常使用。同时还可以及时定位应用程序在被使用过程中出现的应用程序错误,以便应用程序存在的问题能够被及时发现并修复,进而给客户提供更优质的服务。
在本申请所提供的几个实施例中,应该理解到,所揭露的装置和方法,也可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,附图中的流程图和框图显示了根据本发明的多个实施例的装置、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段或代码的一部分,所述模块、程序段或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现方式中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或动作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
另外,在本发明各个实施例中的各功能模块可以集成在一起形成一个独立的部分,也可以是各个模块单独存在,也可以两个或两个以上模块集成形成一个独立的部分。
所述功能如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。
需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
以上所述仅为本发明的优选实施例而已,并不用于限制本发明,对于本领域的技术人员来说,本发明可以有各种更改和变化。凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。
以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应所述以权利要求的保护范围为准。