CN108551411A - 数据采集方法、移动终端及计算机可读存储介质 - Google Patents
数据采集方法、移动终端及计算机可读存储介质 Download PDFInfo
- Publication number
- CN108551411A CN108551411A CN201810402913.4A CN201810402913A CN108551411A CN 108551411 A CN108551411 A CN 108551411A CN 201810402913 A CN201810402913 A CN 201810402913A CN 108551411 A CN108551411 A CN 108551411A
- Authority
- CN
- China
- Prior art keywords
- data
- server
- user behavior
- behavior data
- program
- 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
Classifications
-
- 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
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3051—Monitoring arrangements for monitoring the configuration of the computing system or of the computing system component, e.g. monitoring the presence of processing resources, peripherals, I/O links, software programs
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/22—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks comprising specially adapted graphical user interfaces [GUI]
Abstract
本发明公开了一种数据采集方法、移动终端及计算机可读存储介质,所述方法包括:获取服务器可视化配置的埋点信息;根据所述埋点信息,采集应用程序的用户行为数据;通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器。本发明通过服务器可视化配置的埋点信息,采集应用程序的用户行为数据,并通过动态代理方式上报给服务器;实现了不对应用程序的代码进行入侵;减少了因代码埋点过多,导致应用程序的崩溃、内存过高、OOM泄露的现象。
Description
技术领域
本发明涉及终端技术领域,尤其涉及一种数据采集方法、移动终端及计算机可读存储介质。
背景技术
随着移动互联网技术的发展,我国的移动互联网用户已达到近10亿,在这个大数据时代,如何提高产品的用户活跃度、增加用户量,从而提升品牌知名度已经成为各大互联网App(Application,应用程序)厂商的普遍关注的问题,而通过收集用户行为,进而实现产品的精准化推荐无疑是一种有效的营销手段。
现有技术是通过集成专门负责数据采集的SDK(Software Development Kit,软件开发工具包),并同时配合代码埋点的方式进行,代码埋点是指需要在APP开发过程中,在指定按钮等控件的点击代码内插入代码的方式,在用户使用APP的过程中,点击该控件时,会触发该插入代码,从而采集到用户的行为数据,发送至后台服务器进行数据的接收、处理、计算、展现等一系列操作。
但是该技术存在的问题是,若代码埋点过多,可能会导致终端APP崩溃、内存过高、发生OOM(Out Of MemoryError,内存泄露)等现象。
发明内容
本发明实施例的主要目的在于提供一种数据采集方法、移动终端及计算机可读存储介质,旨在解决现有技术代码埋点过多,导致终端APP崩溃、内存过高、发生OOM的问题。
为实现上述目的,本发明实施例第一方面提供一种数据采集方法,所述方法包括:
获取服务器可视化配置的埋点信息;
根据所述埋点信息,采集应用程序的用户行为数据;
通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器。
可选的,所述获取服务器可视化配置的埋点信息之前还包括:
获取所述应用程序的页面信息;
将所述页面信息上传到所述服务器,以使得所述服务器渲染出所述应用程序的页面。
可选的,所述页面信息包括页面截图和子视图对应的标识符;
所述获取所述应用程序的页面信息包括:
对所述应用程序的页面进行截图,得到页面截图;遍历所述应用程序的页面的视图,得到子视图对应的标识符。
可选的,所述根据所述埋点信息,采集应用程序的用户行为数据之后还包括:
对所述用户行为数据进行匹配;
若匹配成功,则执行通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器步骤。
可选的,所述根据所述埋点信息,采集应用程序的用户行为数据之后还包括:
对所述用户行为数据进行合法性校验;
若通过合法性校验,则执行通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器步骤。
可选的,所述根据所述埋点信息,采集应用程序的用户行为数据之后还包括:据所述用户行为数据生成对应的审计数据;
所述通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器包括:
通过动态代理方式在代理类中将所述审计数据上报给所述服务器。
可选的,所述通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器包括:
根据所述服务器配置的数据上报方式,通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器。
可选的,所述数据上报方式包括实时上报、非实时上报、集中上报、非集中上报中的一种。
此外,为实现上述目的,本发明实施例第二方面提供一种移动终端,所述移动终端包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的数据采集程序,所述数据采集程序被所述处理器执行时实现第一方面所述的数据采集方法的步骤。
再者,为实现上述目的,本发明实施例第三方面提供一种计算机可读存储介质,所述计算机可读存储介质上存储有数据采集程序,所述数据采集程序被处理器执行时实现第一方面所述的数据采集方法的步骤。
本发明实施例提供的数据采集方法、移动终端及计算机可读存储介质,通过服务器可视化配置的埋点信息,采集应用程序的用户行为数据,并通过动态代理方式上报给服务器;实现了不对应用程序的代码进行入侵;减少了因代码埋点过多,导致应用程序的崩溃、内存过高、OOM泄露的现象。
附图说明
图1为实现本发明各个实施例的移动终端的硬件结构示意图;
图2为本发明实施例提供的一种通信网络系统架构图;
图3为本发明实施例的数据采集方法流程示意图;
图4为本发明实施例的数据采集方法另一流程示意图;
图5为本发明实施例的移动终端结构示意图;
图6为本发明实施例的动态代理设置结构示意图。
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。
终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、个人数字助理(Personal Digital Assistant,PDA)、便捷式媒体播放器(Portable Media Player,PMP)、导航装置、可穿戴设备、智能手环、计步器等移动终端,以及诸如数字TV、台式计算机等固定终端。
后续描述中将以移动终端为例进行说明,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。
请参阅图1,其为实现本发明各个实施例的一种移动终端的硬件结构示意图,该移动终端100可以包括:RF(Radio Frequency,射频)单元101、WiFi模块102、音频输出单元103、A/V(音频/视频)输入单元104、传感器105、显示单元106、用户输入单元107、接口单元108、存储器109、处理器110、以及电源111等部件。本领域技术人员可以理解,图1中示出的移动终端结构并不构成对移动终端的限定,移动终端可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
下面结合图1对移动终端的各个部件进行具体的介绍:
射频单元101可用于收发信息或通话过程中,信号的接收和发送,具体的,将基站的下行信息接收后,给处理器110处理;另外,将上行的数据发送给基站。通常,射频单元101包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器、双工器等。此外,射频单元101还可以通过无线通信与网络和其他设备通信。上述无线通信可以使用任一通信标准或协议,包括但不限于GSM(Global System of Mobile communication,全球移动通讯系统)、GPRS(General Packet Radio Service,通用分组无线服务)、CDMA2000(CodeDivision Multiple Access 2000,码分多址2000)、WCDMA(Wideband Code DivisionMultiple Access,宽带码分多址)、TD-SCDMA(Time Division-Synchronous CodeDivision Multiple Access,时分同步码分多址)、FDD-LTE(Frequency DivisionDuplexing-Long Term Evolution,频分双工长期演进)和TDD-LTE(Time DivisionDuplexing-Long Term Evolution,分时双工长期演进)等。
WiFi属于短距离无线传输技术,移动终端通过WiFi模块102可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图1示出了WiFi模块102,但是可以理解的是,其并不属于移动终端的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。
音频输出单元103可以在移动终端100处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将射频单元101或WiFi模块102接收的或者在存储器109中存储的音频数据转换成音频信号并且输出为声音。而且,音频输出单元103还可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出单元103可以包括扬声器、蜂鸣器等等。
A/V输入单元104用于接收音频或视频信号。A/V输入单元104可以包括图形处理器(Graphics Processing Unit,GPU)1041和麦克风1042,图形处理器1041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元106上。经图形处理器1041处理后的图像帧可以存储在存储器109(或其它存储介质)中或者经由射频单元101或WiFi模块102进行发送。麦克风1042可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风1042接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由射频单元101发送到移动通信基站的格式输出。麦克风1042可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。
移动终端100还包括至少一种传感器105,比如光传感器、运动传感器以及其他传感器。具体地,光传感器包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板1061的亮度,接近传感器可在移动终端100移动到耳边时,关闭显示面板1061和/或背光。作为运动传感器的一种,加速计传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别手机姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于手机还可配置的指纹传感器、压力传感器、虹膜传感器、分子传感器、陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。
显示单元106用于显示由用户输入的信息或提供给用户的信息。显示单元106可包括显示面板1061,可以采用液晶显示器(Liquid Crystal Display,LCD)、有机发光二极管(Organic Light-Emitting Diode,OLED)等形式来配置显示面板1061。
用户输入单元107可用于接收输入的数字或字符信息,以及产生与移动终端的用户设置以及功能控制有关的键信号输入。具体地,用户输入单元107可包括触控面板1071以及其他输入设备1072。触控面板1071,也称为触摸屏,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触控面板1071上或在触控面板1071附近的操作),并根据预先设定的程式驱动相应的连接装置。触控面板1071可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器110,并能接收处理器110发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触控面板1071。除了触控面板1071,用户输入单元107还可以包括其他输入设备1072。具体地,其他输入设备1072可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的一种或多种,具体此处不做限定。
进一步的,触控面板1071可覆盖显示面板1061,当触控面板1071检测到在其上或附近的触摸操作后,传送给处理器110以确定触摸事件的类型,随后处理器110根据触摸事件的类型在显示面板1061上提供相应的视觉输出。虽然在图1中,触控面板1071与显示面板1061是作为两个独立的部件来实现移动终端的输入和输出功能,但是在某些实施例中,可以将触控面板1071与显示面板1061集成而实现移动终端的输入和输出功能,具体此处不做限定。
接口单元108用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(I/O)端口、视频I/O端口、耳机端口等等。接口单元108可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端100和外部装置之间传输数据。
存储器109可用于存储软件程序以及各种数据。存储器109可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据手机的使用所创建的数据(比如音频数据、电话本等)等。此外,存储器109可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
处理器110是移动终端的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器109内的软件程序和/或模块,以及调用存储在存储器109内的数据,执行移动终端的各种功能和处理数据,从而对移动终端进行整体监控。处理器110可包括一个或多个处理单元;优选的,处理器110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器110中。
移动终端100还可以包括给各个部件供电的电源111(比如电池),优选的,电源111可以通过电源管理系统与处理器110逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。
尽管图1未示出,移动终端100还可以包括蓝牙模块等,在此不再赘述。
为了便于理解本发明实施例,下面对本发明的移动终端所基于的通信网络系统进行描述。
请参阅图2,图2为本发明实施例提供的一种通信网络系统架构图,该通信网络系统为通用移动通信技术的LTE系统,该LTE系统包括依次通讯连接的UE(User Equipment,用户设备)201,E-UTRAN(Evolved UMTS Terrestrial Radio Access Network,演进式UMTS陆地无线接入网)202,EPC(Evolved Packet Core,演进式分组核心网)203和运营商的IP业务204。
具体地,UE201可以是上述终端100,此处不再赘述。
E-UTRAN202包括eNodeB2021和其它eNodeB2022等。其中,eNodeB2021可以通过回程(backhaul)(例如X2接口)与其它eNodeB2022连接,eNodeB2021连接到EPC203,eNodeB2021可以提供UE201到EPC203的接入。
EPC203可以包括MME(Mobility Management Entity,移动性管理实体)2031,HSS(Home Subscriber Server,归属用户服务器)2032,其它MME2033,SGW(Serving Gate Way,服务网关)2034,PGW(PDN Gate Way,分组数据网络网关)2035和PCRF(Policy andCharging Rules Function,政策和资费功能实体)2036等。其中,MME2031是处理UE201和EPC203之间信令的控制节点,提供承载和连接管理。HSS2032用于提供一些寄存器来管理诸如归属位置寄存器(图中未示)之类的功能,并且保存有一些有关服务特征、数据速率等用户专用的信息。所有用户数据都可以通过SGW2034进行发送,PGW2035可以提供UE 201的IP地址分配以及其它功能,PCRF2036是业务数据流和IP承载资源的策略与计费控制策略决策点,它为策略与计费执行功能单元(图中未示)选择及提供可用的策略和计费控制决策。
IP业务204可以包括因特网、内联网、IMS(IP Multimedia Subsystem,IP多媒体子系统)或其它IP业务等。
虽然上述以LTE系统为例进行了介绍,但本领域技术人员应当知晓,本发明不仅仅适用于LTE系统,也可以适用于其他无线通信系统,例如GSM、CDMA2000、WCDMA、TD-SCDMA以及未来新的网络系统等,此处不做限定。
基于上述移动终端硬件结构以及通信网络系统,提出本发明方法各个实施例。
第一实施例
如图3所示,本发明第一实施例提供一种数据采集方法,该方法用于移动终端,所述方法包括步骤:
S31、获取服务器可视化配置的埋点信息。
在本实施例中,终端上集成了SDK,在服务器上终端用户可通过可视化的方式选择埋点页面、埋点事件等进行统计和分析。
请参考图4所示,在一种实施方式中,所述获取服务器可视化配置的埋点信息之前还包括:
获取所述应用程序的页面信息;
将所述页面信息上传到所述服务器,以使得所述服务器渲染出所述应用程序的页面。
在该实施方式中,应用程序在此并不作限制,可以为网络社交类应用程序,例如浏览器、QQ、微信等应用程序;游戏类应用程序,例如棋牌、网游、休闲娱乐等应用程序;办公类应用程序,例如金山WPS、笔记、邮箱等应用程序。
在该实施方式中,页面信息包括但不限于页面截图和页面控件信息。页面控件信息包括页面的视图树和控件属性信息。其中,控件属性信息包括控件名称、控件ID、HashCode、位置、尺寸、可见性、父子关系和可点击性中的至少一种。
在该实施方式中,所述页面信息包括页面截图和子视图对应的标识符;
所述获取所述应用程序的页面信息包括:
对所述应用程序的页面进行截图,得到页面截图;遍历所述应用程序的页面的视图,得到子视图对应的标识符。
作为示例地,移动终端在初始化SDK时,首先获取服务器可视化配置的埋点信息,例如:用户需要埋点页面、控件事件以及自定义事件等等,保存配置的埋点信息。当进入应用程序的某个Activity页面时,对该Activity页面进行截图生成Bitmap(位图文件),然后遍历该Activity页面的根视图(DecorView)到整个子视图,保存子视图对应的标识符并上传到服务器。
Activity是安卓应用的组件之一,用于展示页面窗口。安卓应用的页面以Activity为载体实现。Activity的生命周期分为onCreate、onStart、onResume、onPause、onStop和onDestroy,具体来说,当Activity被第一次调用时,就会执行onCreate方法。当Activity处于可见状态的时候会调用onStart方法,当Activity可以得到用户焦点的时候会调用onResume方法,当Activity没有被销毁且被重新调用时会调用onRestart方法,当Activity被遮挡住的时候会调用onPause方法,当Activity处于不可见状态的时候会调用onStop方法,当Activity被销毁时会调用onDestory方法。一个页面的展示和消失都需要经过这几个阶段,通过监控Activity的生命周期,就可以监控一个页面的打开、关闭以及用户在页面上停留的时间。
S32、根据所述埋点信息,采集应用程序的用户行为数据;
在本实施例中,用户行为数据包括但不限于以下类型:1)、行为数据,例如时间、地点、人物、交互的内容等;2)、质量数据,例如App运行情况、浏览器加载情况、错误异常等;3)环境数据,例如手机型号、操作系统版本、浏览器UA、地理、运营商、网络环境等;4)、运营数据,例如PV、UV、点击量、日活、留存、渠道来源等。
在一种实施方式中,所述根据所述埋点信息,采集应用程序的用户行为数据之后还包括:
对所述用户行为数据进行匹配;
若匹配成功,则执行通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器步骤。
在该实施方式中,通过对用户行为数据进行匹配,可提高数据上报的准确性。
在一种实施方式中,所述根据所述埋点信息,采集应用程序的用户行为数据之后还包括:
对所述用户行为数据进行合法性校验;
若通过合法性校验,则执行通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器步骤。
在该实施方式中,合法性校验可以校验数据的采集时间、数据的格式、数据的来源、数据的版本号等是否符合预设的合规条件。例如:合规条件为数据采集端当天采集的数据,数据的来源为使用浏览器产生的数据,数据的格式为时间戳为精确到毫秒的13位时间戳,数据的版本号为V1.0;符合所述合规条件的数据校验通过,认为是合规数据,不符合所述合规条件的数据校验不通过,认为是不合规数据。
在另一种实施方式中,所述根据所述埋点信息,采集应用程序的用户行为数据之后还包括:据所述用户行为数据生成对应的审计数据;
所述通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器包括:
通过动态代理方式在代理类中将所述审计数据上报给所述服务器。
一般地,通过SDK所采集的用户行为数据都是彼此独立且分散的。例如,事件A第一次发生时,新增一次事件A的操作数据记录;事件A再次发生时,再新增一次事件A的操作数据记录,两次事件A的操作数据记录之间没有任何关联彼此独立。这样的操作数据记录方式,使得向服务器上报所采集的数据时,每一条被上报的操作数据之间无关联,若某一条操作数据出现漏报或者上报失败,则服务器根本无法察觉,造成服务器端上报数据的异常,影响其准确性。因此,根据所采集的用户行为数据生成对应的审计数据,以使所述服务器能够根据审计数据来校验用户行为数据是否出现漏报、错报、或者上报失败等状况。
S33、通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器。
在本实施例中,需要对ActivityManager的静态变量IActivityManagerSingleton进行反射动态代理设置,从而对各个页面生命周期(Android对页面的启动、暂停、销毁顺序调用)监控,对按钮事件android.view.view的变量ListenerInfo mListenerInfo进行动态代理设置,在代理类中进行对事件统一处理上报。
代理类在程序运行时创建的代理方式被成为动态代理。也就是说,这种情况下,代理类并不是在Java代码中定义的,而是在运行时根据我们在Java代码中的“指示”动态生成的。相比于静态代理,动态代理的优势在于可以很方便的对代理类的函数进行统一的处理,而不用修改每个代理类的函数。
请结合图6进行理解,首先通过Proxy类的newProxyInstance方法获取代理类实例,而后通过这个代理类实例调用代理类的方法,对代理类的方法的调用实际上都会调用InvcoationHandler类的invoke方法,在invoke方法中调用委托类的相应方法,并且可以添加自己的处理逻辑。
在一种实施方式在,所述通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器包括:
根据所述服务器配置的数据上报方式,通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器。
在该实施方式中,所述数据上报方式包括实时上报、非实时上报、集中上报、非集中上报中的一种。
具体地,实时上报即当应用程序启动,行为发生即刻产生日志数据上传给服务器。
非实时上报包括按条数上报、按文件大小上报和/或按时间间隔上报;在有网络的情况下,SDK将获取的应用程序的运行数据压缩成数据文件按照服务器数据上报方式进行数据文件的批量上报,当用户进行锁屏或者切入后台,应用程序都进入了后台,这时用户如果没有杀进程,SDK会在后台进行数据文件的上传,减少数据的丢失,最大可能的将获取到的数据上传至服务器。
集中上报可避免由于应用程序频繁请求服务器,而降低应用程序性能的问题。还可以通过应用程序收集一定时间的用户行为数据,并间隔预定时间实现对用户行为数据进行集中上报,也可以在间隔预定时间后以更好的提高应用性能,并减少各个应用的耗电量。
本发明实施例提供的数据采集方法,通过服务器可视化配置的埋点信息,采集应用程序的用户行为数据,并通过动态代理方式上报给服务器;实现了不对应用程序的代码进行入侵;减少了因代码埋点过多,导致应用程序的崩溃、内存过高、OOM泄露的现象。
第二实施例
参照图5,图5为本发明第二实施例提供一种移动终端,所述移动终端40包括:存储器41、处理器42及存储在所述存储器41上并可在所述处理器42上运行的数据采集程序,所述数据采集程序被所述处理器42执行时,用于实现以下所述的数据采集方法的步骤:
获取服务器可视化配置的埋点信息;
根据所述埋点信息,采集应用程序的用户行为数据;
通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器。
所述数据采集程序被所述处理器42执行时,还用于实现以下所述的数据采集方法的步骤:
获取所述应用程序的页面信息;
将所述页面信息上传到所述服务器,以使得所述服务器渲染出所述应用程序的页面。
所述数据采集程序被所述处理器42执行时,还用于实现以下所述的数据采集方法的步骤:
所述页面信息包括页面截图和子视图对应的标识符;
所述获取所述应用程序的页面信息包括:
对所述应用程序的页面进行截图,得到页面截图;遍历所述应用程序的页面的视图,得到子视图对应的标识符。
所述数据采集程序被所述处理器42执行时,还用于实现以下所述的数据采集方法的步骤:
对所述用户行为数据进行匹配;
若匹配成功,则执行通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器步骤。
所述数据采集程序被所述处理器42执行时,还用于实现以下所述的数据采集方法的步骤:
对所述用户行为数据进行合法性校验;
若通过合法性校验,则执行通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器步骤。
所述数据采集程序被所述处理器42执行时,还用于实现以下所述的数据采集方法的步骤:
所述根据所述埋点信息,采集应用程序的用户行为数据之后还包括:据所述用户行为数据生成对应的审计数据;
所述通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器包括:
通过动态代理方式在代理类中将所述审计数据上报给所述服务器。
所述数据采集程序被所述处理器42执行时,还用于实现以下所述的数据采集方法的步骤:
根据所述服务器配置的数据上报方式,通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器。
所述数据采集程序被所述处理器42执行时,还用于实现以下所述的数据采集方法的步骤:
所述数据上报方式包括实时上报、非实时上报、集中上报、非集中上报中的一种。
本发明实施例提供的移动终端,通过服务器可视化配置的埋点信息,采集应用程序的用户行为数据,并通过动态代理方式上报给服务器;实现了不对应用程序的代码进行入侵;减少了因代码埋点过多,导致应用程序的崩溃、内存过高、OOM泄露的现象。
第三实施例
本发明第三实施例提供一种计算机可读存储介质,所述计算机可读存储介质上存储有数据采集程序,所述数据采集程序被处理器执行时实现第一实施例所述的数据采集方法的步骤。
本发明实施例提供的计算机可读存储介质,通过服务器可视化配置的埋点信息,采集应用程序的用户行为数据,并通过动态代理方式上报给服务器;实现了不对应用程序的代码进行入侵;减少了因代码埋点过多,导致应用程序的崩溃、内存过高、OOM泄露的现象。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
上面结合附图对本发明的实施例进行了描述,但是本发明并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本发明的启示下,在不脱离本发明宗旨和权利要求所保护的范围情况下,还可做出很多形式,这些均属于本发明的保护之内。
Claims (10)
1.一种数据采集方法,其特征在于,所述方法包括:
获取服务器可视化配置的埋点信息;
根据所述埋点信息,采集应用程序的用户行为数据;
通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器。
2.根据权利要求1所述的数据采集方法,其特征在于,所述获取服务器可视化配置的埋点信息之前还包括:
获取所述应用程序的页面信息;
将所述页面信息上传到所述服务器,以使得所述服务器渲染出所述应用程序的页面。
3.根据权利要求2所述的数据采集方法,其特征在于,所述页面信息包括页面截图和子视图对应的标识符;
所述获取所述应用程序的页面信息包括:
对所述应用程序的页面进行截图,得到页面截图;遍历所述应用程序的页面的视图,得到子视图对应的标识符。
4.根据权利要求1所述的数据采集方法,其特征在于,所述根据所述埋点信息,采集应用程序的用户行为数据之后还包括:
对所述用户行为数据进行匹配;
若匹配成功,则执行通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器步骤。
5.根据权利要求1所述的数据采集方法,其特征在于,所述根据所述埋点信息,采集应用程序的用户行为数据之后还包括:
对所述用户行为数据进行合法性校验;
若通过合法性校验,则执行通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器步骤。
6.根据权利要求1所述的数据采集方法,其特征在于,所述根据所述埋点信息,采集应用程序的用户行为数据之后还包括:据所述用户行为数据生成对应的审计数据;
所述通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器包括:
通过动态代理方式在代理类中将所述审计数据上报给所述服务器。
7.根据权利要求1所述的数据采集方法,其特征在于,所述通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器包括:
根据所述服务器配置的数据上报方式,通过动态代理方式在代理类中将所述用户行为数据上报给所述服务器。
8.根据权利要求5所述的数据采集方法,其特征在于,所述数据上报方式包括实时上报、非实时上报、集中上报、非集中上报中的一种。
9.一种移动终端,其特征在于,所述移动终端包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的数据采集程序,所述数据采集程序被所述处理器执行时实现如权利要求1至8中任一项所述的数据采集方法的步骤。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有数据采集程序,所述数据采集程序被处理器执行时实现如权利要求1至8中任一项所述的数据采集方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810402913.4A CN108551411A (zh) | 2018-04-28 | 2018-04-28 | 数据采集方法、移动终端及计算机可读存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810402913.4A CN108551411A (zh) | 2018-04-28 | 2018-04-28 | 数据采集方法、移动终端及计算机可读存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN108551411A true CN108551411A (zh) | 2018-09-18 |
Family
ID=63512907
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810402913.4A Pending CN108551411A (zh) | 2018-04-28 | 2018-04-28 | 数据采集方法、移动终端及计算机可读存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN108551411A (zh) |
Cited By (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108845918A (zh) * | 2018-04-28 | 2018-11-20 | 努比亚技术有限公司 | 一种信息采集方法、终端及计算机可读存储介质 |
CN109522191A (zh) * | 2018-10-16 | 2019-03-26 | 深圳壹账通智能科技有限公司 | 一种采集交互行为指令的属性信息的方法及装置 |
CN109542529A (zh) * | 2018-10-26 | 2019-03-29 | 深圳壹账通智能科技有限公司 | 基于函数名称的埋点方法、装置、计算机设备及存储介质 |
CN109766253A (zh) * | 2018-12-15 | 2019-05-17 | 平安证券股份有限公司 | 一种性能数据发送方法、装置、计算机设备及存储介质 |
CN110221896A (zh) * | 2019-06-11 | 2019-09-10 | 北京金山安全软件有限公司 | 一种界面显示方法和装置 |
CN110661681A (zh) * | 2019-09-12 | 2020-01-07 | 北京市天元网络技术股份有限公司 | 埋点设计方法和设备 |
CN110851339A (zh) * | 2019-10-12 | 2020-02-28 | 平安普惠企业管理有限公司 | 一种埋点数据的上报方法、装置、存储介质和终端设备 |
CN110908880A (zh) * | 2019-11-01 | 2020-03-24 | 北京金山安全软件有限公司 | 埋点代码注入方法、事件上报方法及其相关设备 |
CN111367562A (zh) * | 2018-12-25 | 2020-07-03 | 阿里巴巴集团控股有限公司 | 数据采集方法、装置、存储介质及处理器 |
CN111726402A (zh) * | 2020-06-09 | 2020-09-29 | 百度在线网络技术(北京)有限公司 | 用户行为数据处理方法、装置、电子设备及存储介质 |
CN117289877A (zh) * | 2023-11-23 | 2023-12-26 | 云筑信息科技(成都)有限公司 | 一种基于服务网格的通用文件存储动态代理方法 |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106294091A (zh) * | 2016-08-11 | 2017-01-04 | 福建富士通信息软件有限公司 | 一种无侵入式日志拦截性能分析方法及系统 |
CN106571949A (zh) * | 2016-09-23 | 2017-04-19 | 北京五八信息技术有限公司 | 埋点处理方法及装置 |
CN106933472A (zh) * | 2017-05-20 | 2017-07-07 | 南京西桥科技有限公司 | 一种基于手机app的用户行为数据采集系统及其控制方法 |
CN106970789A (zh) * | 2017-03-07 | 2017-07-21 | 武汉斗鱼网络科技有限公司 | 一种Android端基于AOP和AspectJ的日志自动埋点方法及系统 |
CN107145489A (zh) * | 2016-03-01 | 2017-09-08 | 阿里巴巴集团控股有限公司 | 一种基于云平台的客户端应用的信息统计方法和装置 |
CN107273118A (zh) * | 2017-05-31 | 2017-10-20 | 湖南机友科技有限公司 | 一种应用程序多开的实现方法及装置 |
CN107423048A (zh) * | 2017-04-14 | 2017-12-01 | 网易乐得科技有限公司 | 数据收集的方法、装置、介质和计算设备 |
-
2018
- 2018-04-28 CN CN201810402913.4A patent/CN108551411A/zh active Pending
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107145489A (zh) * | 2016-03-01 | 2017-09-08 | 阿里巴巴集团控股有限公司 | 一种基于云平台的客户端应用的信息统计方法和装置 |
CN106294091A (zh) * | 2016-08-11 | 2017-01-04 | 福建富士通信息软件有限公司 | 一种无侵入式日志拦截性能分析方法及系统 |
CN106571949A (zh) * | 2016-09-23 | 2017-04-19 | 北京五八信息技术有限公司 | 埋点处理方法及装置 |
CN106970789A (zh) * | 2017-03-07 | 2017-07-21 | 武汉斗鱼网络科技有限公司 | 一种Android端基于AOP和AspectJ的日志自动埋点方法及系统 |
CN107423048A (zh) * | 2017-04-14 | 2017-12-01 | 网易乐得科技有限公司 | 数据收集的方法、装置、介质和计算设备 |
CN106933472A (zh) * | 2017-05-20 | 2017-07-07 | 南京西桥科技有限公司 | 一种基于手机app的用户行为数据采集系统及其控制方法 |
CN107273118A (zh) * | 2017-05-31 | 2017-10-20 | 湖南机友科技有限公司 | 一种应用程序多开的实现方法及装置 |
Non-Patent Citations (1)
Title |
---|
HADOOP_DEV 博客园: ""java中代理,静态代理,动态代理以及spring aop代理方式,实现原理统一汇总"", 《博客园HTTPS://WWW.CNBLOGS.COM/HADOOP-DEV/P/7095464.HTML》 * |
Cited By (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108845918A (zh) * | 2018-04-28 | 2018-11-20 | 努比亚技术有限公司 | 一种信息采集方法、终端及计算机可读存储介质 |
CN109522191A (zh) * | 2018-10-16 | 2019-03-26 | 深圳壹账通智能科技有限公司 | 一种采集交互行为指令的属性信息的方法及装置 |
CN109542529A (zh) * | 2018-10-26 | 2019-03-29 | 深圳壹账通智能科技有限公司 | 基于函数名称的埋点方法、装置、计算机设备及存储介质 |
CN109542529B (zh) * | 2018-10-26 | 2022-04-05 | 深圳壹账通智能科技有限公司 | 基于函数名称的埋点方法、装置、计算机设备及存储介质 |
CN109766253A (zh) * | 2018-12-15 | 2019-05-17 | 平安证券股份有限公司 | 一种性能数据发送方法、装置、计算机设备及存储介质 |
CN111367562A (zh) * | 2018-12-25 | 2020-07-03 | 阿里巴巴集团控股有限公司 | 数据采集方法、装置、存储介质及处理器 |
CN111367562B (zh) * | 2018-12-25 | 2023-05-02 | 阿里巴巴集团控股有限公司 | 数据采集方法、装置、存储介质及处理器 |
CN110221896A (zh) * | 2019-06-11 | 2019-09-10 | 北京金山安全软件有限公司 | 一种界面显示方法和装置 |
CN110661681B (zh) * | 2019-09-12 | 2021-06-04 | 北京市天元网络技术股份有限公司 | 埋点设计方法和设备 |
CN110661681A (zh) * | 2019-09-12 | 2020-01-07 | 北京市天元网络技术股份有限公司 | 埋点设计方法和设备 |
CN110851339A (zh) * | 2019-10-12 | 2020-02-28 | 平安普惠企业管理有限公司 | 一种埋点数据的上报方法、装置、存储介质和终端设备 |
CN110908880A (zh) * | 2019-11-01 | 2020-03-24 | 北京金山安全软件有限公司 | 埋点代码注入方法、事件上报方法及其相关设备 |
CN110908880B (zh) * | 2019-11-01 | 2023-10-13 | 北京金山安全软件有限公司 | 埋点代码注入方法、事件上报方法及其相关设备 |
CN111726402A (zh) * | 2020-06-09 | 2020-09-29 | 百度在线网络技术(北京)有限公司 | 用户行为数据处理方法、装置、电子设备及存储介质 |
CN111726402B (zh) * | 2020-06-09 | 2023-03-24 | 百度在线网络技术(北京)有限公司 | 用户行为数据处理方法、装置、电子设备及存储介质 |
CN117289877A (zh) * | 2023-11-23 | 2023-12-26 | 云筑信息科技(成都)有限公司 | 一种基于服务网格的通用文件存储动态代理方法 |
CN117289877B (zh) * | 2023-11-23 | 2024-03-19 | 云筑信息科技(成都)有限公司 | 一种基于服务网格的通用文件存储动态代理方法 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN108551411A (zh) | 数据采集方法、移动终端及计算机可读存储介质 | |
CN108391025A (zh) | 一种网络访问管理方法、移动终端及计算机可读存储介质 | |
CN108268835A (zh) | 手语翻译方法、移动终端及计算机可读存储介质 | |
CN107463481A (zh) | 数据交互方法、移动终端和存储介质 | |
CN108762876A (zh) | 一种输入法切换方法、移动终端以及计算机存储介质 | |
CN107734128A (zh) | 一种诈骗号码识别方法及设备 | |
CN107102878A (zh) | 一种应用启动方法、移动终端以及计算机可读存储介质 | |
CN107678634A (zh) | 游戏模式的设置方法及终端、计算机可读存储介质 | |
CN108172161A (zh) | 基于柔性屏的显示方法、移动终端及计算机可读存储介质 | |
CN109117105A (zh) | 一种协同桌面交互调控方法、设备及计算机可读存储介质 | |
CN108536383A (zh) | 一种游戏控制方法、设备及计算机可读存储介质 | |
CN108241808A (zh) | 识别码显示控制方法、终端及计算机可读存储介质 | |
CN110086925A (zh) | 一种应用处理方法及移动终端 | |
CN109309762A (zh) | 消息处理方法、装置、移动终端以及存储介质 | |
CN109495376A (zh) | 群消息筛选方法、移动终端及计算机可读存储介质 | |
CN108762639A (zh) | 一种物理按键的控制方法、移动终端及存储介质 | |
CN108366303A (zh) | 一种视频播放方法、移动终端及计算机可读存储介质 | |
CN108377292A (zh) | 解决内存泄露的方法、终端、服务器及计算机存储介质 | |
CN107911778A (zh) | 一种基于并联喇叭的播放方法、移动终端及可读存储介质 | |
CN107634940A (zh) | 一种流量使用的控制方法、终端、服务器及可读存储介质 | |
CN109388947A (zh) | 一种后台管理方法、设备及计算机可读存储介质 | |
CN108768831A (zh) | 聊天记录的分享方法、移动终端及计算机可读存储介质 | |
CN108833686A (zh) | 寻呼消息处理方法、终端设备、网络侧设备及存储介质 | |
CN108040330A (zh) | WiFi定向传输方法、移动终端及可读存储介质 | |
CN109379719A (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: 20180918 |
|
RJ01 | Rejection of invention patent application after publication |