CN112565306B - 一种app隐私数据收集的第三方服务器识别方法 - Google Patents
一种app隐私数据收集的第三方服务器识别方法 Download PDFInfo
- Publication number
- CN112565306B CN112565306B CN202110203313.7A CN202110203313A CN112565306B CN 112565306 B CN112565306 B CN 112565306B CN 202110203313 A CN202110203313 A CN 202110203313A CN 112565306 B CN112565306 B CN 112565306B
- Authority
- CN
- China
- Prior art keywords
- app
- server
- party
- android
- data collection
- 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.)
- Active
Links
- 238000000034 method Methods 0.000 title claims abstract description 65
- 238000013480 data collection Methods 0.000 title claims abstract description 28
- 230000006854 communication Effects 0.000 claims abstract description 30
- 238000001514 detection method Methods 0.000 claims abstract description 24
- 238000001914 filtration Methods 0.000 claims abstract description 6
- 238000004590 computer program Methods 0.000 claims description 21
- 230000006870 function Effects 0.000 claims description 10
- 238000006243 chemical reaction Methods 0.000 claims description 3
- 238000012545 processing Methods 0.000 claims description 3
- 238000004891 communication Methods 0.000 abstract description 15
- 238000005516 engineering process Methods 0.000 description 6
- 238000009825 accumulation Methods 0.000 description 4
- 238000012360 testing method Methods 0.000 description 4
- 238000007689 inspection Methods 0.000 description 3
- 238000011161 development Methods 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 241000282693 Cercopithecidae Species 0.000 description 1
- 230000006399 behavior Effects 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 230000007547 defect Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 238000004806 packaging method and process Methods 0.000 description 1
- 238000002360 preparation method Methods 0.000 description 1
- 238000007619 statistical method Methods 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/14—Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic
- H04L63/1408—Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic by monitoring network traffic
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/62—Protecting access to data via a platform, e.g. using keys or access control rules
- G06F21/6218—Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database
- G06F21/6245—Protecting personal data, e.g. for financial or medical purposes
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/02—Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
- H04L63/0227—Filtering policies
- H04L63/0236—Filtering by address, protocol, port number or service, e.g. IP-address or URL
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/10—Network architectures or network communication protocols for network security for controlling access to devices or network resources
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Hardware Design (AREA)
- General Engineering & Computer Science (AREA)
- Signal Processing (AREA)
- Computer Networks & Wireless Communication (AREA)
- Computing Systems (AREA)
- Theoretical Computer Science (AREA)
- Bioethics (AREA)
- General Health & Medical Sciences (AREA)
- Health & Medical Sciences (AREA)
- Medical Informatics (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Software Systems (AREA)
- Databases & Information Systems (AREA)
- Telephonic Communication Services (AREA)
Abstract
本发明公开一种移动应用隐私数据收集的第三方服务器识别方法,包括:S1.获取移动终端中与目标服务器进行通信的app进程信息;S2.拦截app进程与目标服务器之间的通信过程所调用的函数,输出地址和堆栈信息;S3.对输出的堆栈信息进行过滤;S4.判断数据库中是否存在栈底包名与目标服务器地址之间的对应关系;S5.对于app进程与目标服务器地址之间的通信过程,依次执行S2至S4;S6.对数据库中每一对应关系的计数值进行阈值判断。本发明可自动识别app与不可信的第三方的服务器通信,方便确认隐私信息收集责任主体,可用于自动化app合规性检测,以及隐私信息保护的安全检测。
Description
技术领域
本发明涉及Android操作系统安全技术领域,尤其涉及一种移动应用隐私数据收集的第三方服务器识别方法、电子设备及存储介质,属于智能移动终端安全领域。
背景技术
在移动网络时代,智能移动终端,例如:手机,由于其便携性、成本低等优点日益成为用户进行各类网络活动的主要终端形态。相比传统移动终端,智能移动终端拥有更高性能的处理器、更大的存储空间、更高的移动网络数据传输能力以及开放的第三方移动终端操作系统,因此借助智能移动终端可以开展大量业务应用,处理更多的个人隐私数据。随着应用软件技术的快速发展,人们的手机上往往安装了大量的应用程序(app),通过app人们可以进行各种各样的业务操作,同时在app上人们也输入了大量的个人隐私信息,这些个人隐私信息有被滥用的风险。这一风险逐步被社会广泛认识和关注。政府监管部门出台多个文件推进app隐私信息收集安全监管,开展app违法违规隐私信息收集的专项治理活动。
在国标《信息安全技术个人信息安全规范》(GB/T35273-2020)中新增了关于“第三方接入管理”的详细规定。第三方接入,主要是指在互联网产品或服务的过程中,接入了第三方的产品或服务。一旦这些第三方接入的产品或服务在没有经过用户同意的情况下,收集了各类与用户密切相关的敏感的隐私信息(例如银行账号,生物特征信息等),并传输到第三方服务器,甚至境外服务器,将会引发极大的个人隐私数据风险,严重的可能会危害国家安全。
因此从保护隐私数据安全的角度出发,往往需要检测app与互联网发生通信时所连接的诸多服务器,哪些服务器是可信任的app的后端服务器,哪些是可疑的第三方服务器(如app嵌入组件或sdk等所连接的服务器)。在发现app在收集个人隐私信息时,就需要明确个人隐私信息是发往app的后端服务器,还是不可信的第三方服务器。特别需要识别出收集个人隐私信息的第三方服务器。这一检测技术有助于确定违法违规隐私信息收集的责任主体。
为了识别app收集个人隐私信息的后端服务器和第三方服务器,通常采用Wireshark等抓包工具进行抓包,再通过人工分析的方式来进行。这种方式很难实现自动化,无法满足大规模检测的需求。
现有的技术方案:现有技术中,用于识别app收集个人隐私信息的后端服务器和第三方服务器方法,一般是通过使用网络抓包工具,或者使用深度包检测(DPI)技术,识别app与互联网通信时的各种流量,进而抓出通信的IP、URL,通过人工分析的方式判断哪些IP、URL是app的业务后端服务器,哪些IP、URL是第三方服务器。
现有技术的缺点:1)利用网络抓包工具进行抓包分析,通过抓取网络中有指定特征的流量包,对流量包进行协议分析,找出数据包的目的地址,进行分析判断。这样检测,虽然操作简单,但缺点是需要做人工分析判断,难以实现自动化。2)深度包检测(DPI)技术,需要专业的DPI设备并联或串联到系统中,将流量重复复制给DPI设备中进行分析。DPI设备是针对整个网络流程进行分析,而不是针对具体某个app做分析。另外,设备部署成本高,设备的迭代升级困难。
有鉴于此,如何自动识别app与互联网通信时的各种数据流量;以及如何识别哪些数据是发给app业务后台服务器(可信服务器)、哪些是发第三方服务器(不可信服务器),都是本领域技术人员所急需解决的技术问题。
发明内容
为了解决上述问题,本发明提供一种移动应用隐私数据收集的第三方服务器识别方法、电子设备及存储介质。通过使用本发明的上述识别方法、电子设备及存储介质,能够自动识别app与互联网通信时的各种数据流量;以及识别哪些数据是发给app业务后台服务器(可信服务器)、哪些是发第三方服务器(不可信服务器)。其优点是不需要做人工分析判断,能够实现自动化。
本发明提供一种移动应用隐私数据收集的第三方服务器识别方法,用于Android移动终端,该方法包括如下步骤:
S1.获取Android移动终端中与目标服务器进行通信的所有app的进程信息;
S2.拦截所述app的所述进程与所述目标服务器之间的通信过程所调用的函数,输出目标服务器地址[B]和所述通信过程所调用的堆栈信息,其中,所述堆栈信息包括多个Android包名;
S3.对输出的所述堆栈信息进行过滤,提取经过滤的堆栈信息中的最后一个Android包名,并保留该Android包名的前三个字段,记为栈底包名[A];
S4.判断数据库中是否存在所述栈底包名[A]与所述目标服务器地址[B]之间的对应关系;如果不存在,将该对应关系存储到数据库中,并将该对应关系的计数值[C]设置为1;否则,将该对应关系的计数值[C]增加1;
S5.对于所述app的所述进程与所述目标服务器地址[B]之间的每一通信过程,依次执行步骤S2至S4,直至符合预定的条件时退出;
S6.对数据库中每一对应关系的计数值[C]进行阈值判断,以确定所述目标服务器地址[B]对应于第三方服务器,还是对应于所述app的自有服务器。
可选地,所述步骤S1中:通过检测模块对Android系统中的zygote进程进行控制以执行所述获取操作;其中,所述目标服务器地址[B]至少包括URL地址和/或IP地址。
可选地,所述步骤S1中:在所述Android移动终端中通过adb命令安装所述app,并利用第三方框架对所述app进行模拟点击,以触发所述app的所述进程与所述目标服务器之间的通信过程;其中,所述第三方框架包括MonkeyRunner框架。
可选地,所述步骤S2中:检测模块调用HOOK模块拦截系统中所述通信过程所调用的函数。
可选地,所述步骤S3中,所述对输出的堆栈信息进行过滤包括:将所述堆栈信息中以“java”、“android”、“com.java”、以及“com.android”开头的Android包信息剔除。
可选地,所述步骤S6中:对所述计数值[C]做取对数转换处理,将得到的对数值ln([C])与预设阈值X进行比较;当满足ln([C])≥预设阈值X时,确定所述目标服务器地址[B]对应于第三方服务器;否则,确定所述目标服务器地址[B]对应于所述app的自有服务器。
可选地,所述预设阈值X可以根据所检测到的app数量、检测场景、误报率、和/或漏报率进行设置和调整。
可选地,所述Android移动终端包括:智能手机、平板电脑、笔记本电脑、可穿戴智能设备、智能家电、车载智能终端、电纸书、PDA中的一种或多种。
本发明还提供一种用于移动应用隐私数据收集的第三方服务器识别的电子设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其中,所述处理器执行所述计算机程序时实现上述方法的步骤。
本发明还提供一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其中,所述计算机程序被处理器执行时实现上述方法的步骤。
本发明技术方案带来的有益效果:
本发明提供了一种移动应用隐私数据收集的第三方服务器识别方法、电子设备及存储介质。本发明的技术方案可自动识别app与不可信的第三方的服务器通信,方便确认隐私信息收集责任主体,可用于自动化app合规性检测,以及隐私信息保护的安全检测,特别是对境外服务器收集个人隐私信息的自动化识别检测。
附图说明
图1为本发明的一种移动应用隐私数据收集的第三方服务器识别方法的流程图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,可以理解的是,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
缩略语和关键术语定义:
·挂钩(HOOK):是一系列技术,这些技术通过截获在软件组件之间传递的函数调用、消息或事件来更改或增强操作系统、应用程序或其他软件组件的行为。
·移动应用(app):是设计为在诸如移动电话、平板电脑或穿戴设备之类的移动设备上运行的计算机程序或软件应用程序。
·软件开发工具包(SDK):是指辅助开发某一类软件的相关文档、范例代码、接口组件、打包工具等的集合。
·深度包检测(DPI):是一种可详细检查通过计算机网络发送数据的技术。
本发明提供一种移动应用隐私数据收集的第三方服务器识别方法、电子设备及存储介质。本发明的技术方案基于挂钩(HOOK)技术,跟踪代码与通信数据的对应关系,通过统计学方法判断app是否与第三方服务器通信,可用于自动化的app合规性检测,隐私信息保护的安全检测,通过本检测识别方法可对隐私信息收集的责任主体进行判断。具体实施例如下:
实施例一:
在本发明的该实施例中,所述移动应用隐私数据收集的第三方服务器识别方法,包括如下步骤:
步骤A1:在手机系统中安装检测模块,替换Android系统的app_process应用来控制zygote进程,进而控制手机上所有的app进程,实现在被测试app启动前引入自身的代码,完成测试手机的环境准备。
检测模块通过挂钩(HOOK)技术,拦截系统中与通信相关的函数,包括第三方库(如okhttp)的函数,输出HOOK到的目标服务器URL参数,以及通信函数的堆栈信息。
步骤A2:在手机上通过adb命令安装应用,并利用MonkeyRunner等第三方框架对app进行模拟点击,触发app与服务器通信,通信发生时,输出通信调用过程的堆栈信息,分析堆栈信息剔除以“java”、或者“android”为开头的信息,取栈底最后一行的包名,并保留前三个字段,定位具体调用通信的代码段,记录为【A】。
举例来说:
首先,输出的所述通信调用过程的堆栈信息内容如下:
java.lang.Exception
at com.android.okhttp.internal.hHttpURLConnectionImpl.getInputStream(Native Method)
at com.android.okhttp.internal.hDelegatingHttpsURLConnection.getInputStream(DelegatingHttpsURLConnection.java:210)
at com.android.okhttp.internal.hHttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java)
at com.android.okhttp.internal.hHttpsURLConnectionImpl.getInputStream(Native Method)
at com.crashsdk.a.c.a(ProGuard:33)
at com.crashsdk.a.h.b(ProGuard:55)
at com.crashsdk.a.h.d(ProGuard:12)
at com.crashsdk.a.h.b(ProGuard:18)
at com.crashsdk.a.e.a(ProGuard:5)
at com.crashsdk.b.a(ProGuard:84)
at com.crashsdk.a.h.b(ProGuard:25)
at com.crashsdk.a.h.a(ProGuard:49)
at com.crashsdk.a.e.run(ProGuard:5)
at com.crashsdk.a.f.a(ProGuard:23)
at com.crashsdk.a.e.run(ProGuard:11)
at android.os.Handler.handleCallback(Handler.java:751)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:154)
at android.os.HandlerThread.run(HandlerThread.java:61)
进一步地,从上述堆栈信息中剔除以“java”、以及“android”为开头的信息,经过滤得到:
java.lang.Exception
at com.crashsdk.a.c.a(ProGuard:33)
at com.crashsdk.a.h.b(ProGuard:55)
at com.crashsdk.a.h.d(ProGuard:12)
at com.crashsdk.a.h.b(ProGuard:18)
at com.crashsdk.a.e.a(ProGuard:5)
at com.crashsdk.b.a(ProGuard:84)
at com.crashsdk.a.h.b(ProGuard:25)
at com.crashsdk.a.h.a(ProGuard:49)
at com.crashsdk.a.e.run(ProGuard:5)
at com.crashsdk.a.f.a(ProGuard:23)
at com.crashsdk.a.e.run(ProGuard:11)
最后,取栈底最后一行的包名,将其保留前三个字段。例如在该实施例中为:“com.crashsdk.a”。步骤A3:将检测模块HOOK到的目标服务器的具体URL参数或者IP,记录为【B】,将【A】-【B】的对应关系存储到数据库中。
步骤A4:如果数据库中已经有【A】-【B】的对应关系,则进行计数增1,也就是记录历史上遇到了多少次,我们将这个次数记录为【C】。如下表1所示:
表1
Pkgname | URL | Count |
【A】 | 【B】 | 【C】(例如,5) |
步骤A5:在历史数据库记录【A】-【B】的对应关系数量越多,通信是发往第三方服务器的概率越大。分析如下:
【A】有两种可能:app自有Pkgname包名(代码)、第三方sdk的Pkgname包名(代码),【B】有两种可能:app自有服务器,第三方sdk的服务器,因此两者的对应关系的组合排列有以下四种情况:
·情况1:app自有代码与app自有服务器通信;
·情况2:app自有代码与第三方sdk的服务器通信;
·情况3:第三方sdk的代码与app自有服务器通信;
·情况4:第三方sdk的代码与第三方sdk的服务器通信。
对于情况1,因为app自有代码独特性强(不同app的代码不同),app自有服务器独特性强(不同app的服务器不同),因此两者配对的历史积累数量较少。
对于情况2,因为app自有代码独特性强(不同app的代码不同),第三方sdk的服务器特征性弱(不同app可能集成相同的sdk,相同sdk的后台服务器地址一致),由于app数量远远大于sdk数量,因此两者配对的历史积累数量较少。
对于情况3,因为第三方sdk代码独特性弱(不同app可能集成相同的sdk),app自有服务器特征性强(不同app的服务器不同),由于app数量远远大于sdk数量,因此两者配对的历史积累数量较少。
对于情况4,因为第三方sdk代码独特性弱(不同app可能集成相同的sdk),第三方sdk的服务器特征性弱(不同app可能集成相同的sdk,相同sdk的后台服务器地址一致),因此两者配对的历史积累数量较多。
因此,基于app数量远远大于sdk数量这一客观现实,当【C】大于某一数值时,说明相同的(代码-服务器)关系出现次数超过阈值,可以认为这段代码是第三方sdk的代码,服务器是第三方sdk的服务器,通信是发往第三方服务器的。
根据统计学规律,为消除统计数据的方差影响,将【C】做取对数转换处理,【C】对数值大于某一阈值X(如:ln(【C】)=X)时,我们即认为通信是发往第三方服务器的。其中阈值X,可根据检测的app数量、检测场景、误报和漏报率要求等因素,进行设置和调整。
如图1所示,本发明的该实施例提供一种移动应用隐私数据收集的第三方服务器识别方法,用于Android移动终端,该方法包括如下步骤:
S1.获取Android移动终端中与目标服务器进行通信的所有app的进程信息;
S2.拦截所述app的所述进程与所述目标服务器之间的通信过程所调用的函数,输出目标服务器地址[B]和所述通信过程所调用的堆栈信息,其中,所述堆栈信息包括多个Android包名;
S3.对输出的所述堆栈信息进行过滤,提取经过滤的堆栈信息中的最后一个Android包名,并保留该Android包名的前三个字段,记为栈底包名[A];
S4.判断数据库中是否存在所述栈底包名[A]与所述目标服务器地址[B]之间的对应关系;如果不存在,将该对应关系存储到数据库中,并将该对应关系的计数值[C]设置为1;否则,将该对应关系的计数值[C]增加1;
S5.对于所述app的所述进程与所述目标服务器地址[B]之间的每一通信过程,依次执行步骤S2至S4,直至符合预定的条件时退出;
S6.对数据库中每一对应关系的计数值[C]进行阈值判断,以确定所述目标服务器地址[B]对应于第三方服务器,还是对应于所述app的自有服务器。
可选地,所述Android移动终端包括:智能手机、平板电脑、笔记本电脑、可穿戴智能设备、智能家电、车载智能终端、电纸书、PDA中的一种或多种。
在本发明的该实施例中,同时提供一种用于移动应用隐私数据收集的第三方服务器识别的电子设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其中,所述处理器执行所述计算机程序时实现上述移动应用隐私数据收集的第三方服务器识别方法的步骤。
在本发明的该实施例中,还提供一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其中,所述计算机程序被处理器执行时实现上述移动应用隐私数据收集的第三方服务器识别方法的步骤。
实施例二:
在本发明的该实施例中,所述移动应用隐私数据收集的第三方服务器识别方法,包括如下步骤: 步骤B1:将待测试app部署到安装有测试框架的测试手机上,app与“www.crashsdk.cn”域名通信,检测模块通过挂钩(HOOK)技术,输出某一次通信所调用的堆栈信息,例如:
java.lang.Exception
at
com.android.okhttp.internal.hHttpURLConnectionImpl.getInputStream(Native Method)
at com.android.okhttp.internal.hDelegatingHttpsURLConnection.getInputStream(DelegatingHttpsURLConnection.java:210)
at com.android.okhttp.internal.hHttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java)
at com.android.okhttp.internal.hHttpsURLConnectionImpl.getInputStream(Native Method)
at com.crashsdk.a.c.a(ProGuard:33)
at com.crashsdk.a.h.b(ProGuard:55)
at com.crashsdk.a.h.d(ProGuard:12)
at com.crashsdk.a.h.b(ProGuard:18)
at com.crashsdk.a.e.a(ProGuard:5)
at com.crashsdk.b.a(ProGuard:84)
at com.crashsdk.a.h.b(ProGuard:25)
at com.crashsdk.a.h.a(ProGuard:49)
at com.crashsdk.a.e.run(ProGuard:5)
at com.crashsdk.a.f.a(ProGuard:23)
at com.crashsdk.a.e.run(ProGuard:11)
at android.os.Handler.handleCallback(Handler.java:751)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:154)
at android.os.HandlerThread.run(HandlerThread.java:61)
进一步地,从上述堆栈信息中剔除以“java”、以及“android”为开头的信息,经过滤得到:
java.lang.Exception
at com.crashsdk.a.c.a(ProGuard:33)
at com.crashsdk.a.h.b(ProGuard:55)
at com.crashsdk.a.h.d(ProGuard:12)
at com.crashsdk.a.h.b(ProGuard:18)
at com.crashsdk.a.e.a(ProGuard:5)
at com.crashsdk.b.a(ProGuard:84)
at com.crashsdk.a.h.b(ProGuard:25)
at com.crashsdk.a.h.a(ProGuard:49)
at com.crashsdk.a.e.run(ProGuard:5)
at com.crashsdk.a.f.a(ProGuard:23)
at com.crashsdk.a.e.run(ProGuard:11)
最后,取栈底最后一行的包名,将其保留前三个字段。例如在该实施例中为:“com.crashsdk.a”。
步骤B2:在数据库中记录“com.crashsdk.a”与“www.crashsdk.cn”的关联关系;
步骤B3:通过对大量app的自动化测试,并将HOOK到对应关系记录到数据库,包括记录历史统计数据Count。如下表2所示:
表2
Pkgname | URL | Count |
com.crashsdk.a | www.crashsdk.cn | 1000 |
步骤B4:假设本次检测阈值X取X=6.9,当对统计的关联数值(1000)取对数后,其对数值为6.91,大于阈值X=6.9,我们认为“www.crashsdk.cn”是一个第三方服务器,相关app与“www.crashsdk.cn”的通信是发向第三方服务器的,相关的隐私信息收集存在高度安全风险。
在本发明的该实施例中,同时提供一种用于移动应用隐私数据收集的第三方服务器识别的电子设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其中,所述处理器执行所述计算机程序时实现上述移动应用隐私数据收集的第三方服务器识别方法的步骤。
在本发明的该实施例中,还提供一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其中,所述计算机程序被处理器执行时实现上述移动应用隐私数据收集的第三方服务器识别方法的步骤。
本发明的所述用于移动应用隐私数据收集的第三方服务器识别的电子设备如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明实现上述实施例方法中的全部或部分流程,也可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。其中,所述计算机程序包括计算机程序代码,所述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读介质可以包括:能够携带所述计算机程序代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、电载波信号、电信信号以及软件分发介质等。需要说明的是,所述计算机可读介质包含的内容可以根据司法管辖区内立法和专利实践的要求进行适当的增减,例如在某些司法管辖区,根据立法和专利实践,计算机可读介质不包括电载波信号和电信信号。
尽管结合优选实施方案具体展示和介绍了本发明,但所属领域的技术人员应该明白,在不脱离所附权利要求书所限定的本发明的精神和范围内,在形式上和细节上可以对本发明做出各种变化,均为本发明的保护范围。
Claims (9)
1.一种移动应用隐私数据收集的第三方服务器识别方法,其特征在于,该方法包括如下步骤:
S1.获取Android移动终端中与目标服务器进行通信的所有app的进程信息;
S2.拦截所述app的所述进程与所述目标服务器之间的通信过程所调用的函数,输出目标服务器地址[B]和所述通信过程所调用的堆栈信息,其中,所述堆栈信息包括多个Android包名;
S3.对输出的所述堆栈信息进行过滤,提取经过滤的堆栈信息中的最后一个Android包名,并保留该Android包名的前三个字段,记为栈底包名[A];
S4.判断数据库中是否存在所述栈底包名[A]与所述目标服务器地址[B]之间的对应关系;如果不存在,将该对应关系存储到数据库中,并将该对应关系的计数值[C]设置为1;否则,将该对应关系的计数值[C]增加1;
S5.对于所述app的所述进程与所述目标服务器地址[B]之间的每一通信过程,依次执行步骤S2至S4,直至符合预定的条件时退出;
S6.对数据库中每一对应关系的计数值[C]进行阈值判断,以确定所述目标服务器地址[B]对应于第三方服务器,还是对应于所述app的自有服务器;
其中,所述步骤S3中,所述对输出的所述堆栈信息进行过滤,包括:将所述堆栈信息中以“java”、“android”、“com.java”、以及“com.android”开头的Android包信息剔除。
2.根据权利要求1所述的移动应用隐私数据收集的第三方服务器识别方法,其特征在于,所述步骤S1中:通过检测模块对Android系统中的zygote进程进行控制以执行所述获取操作;其中,所述目标服务器地址[B]至少包括URL地址和/或IP地址。
3.根据权利要求1所述的移动应用隐私数据收集的第三方服务器识别方法,其特征在于,所述步骤S1中:在所述Android移动终端中通过adb命令安装所述app,并利用第三方框架对所述app进行模拟点击,以触发所述app的所述进程与所述目标服务器之间的通信过程;其中,所述第三方框架包括MonkeyRunner框架。
4.根据权利要求2或3所述的移动应用隐私数据收集的第三方服务器识别方法,其特征在于,所述步骤S2中:检测模块调用HOOK模块拦截系统中所述通信过程所调用的函数。
5.根据权利要求1所述的移动应用隐私数据收集的第三方服务器识别方法,其特征在于,所述步骤S6中:对所述计数值[C]做取对数转换处理,将得到的对数值ln([C])与预设阈值X进行比较;当满足ln([C])≥预设阈值X时,确定所述目标服务器地址[B]对应于第三方服务器;否则,确定所述目标服务器地址[B]对应于所述app的自有服务器。
6.根据权利要求5所述的移动应用隐私数据收集的第三方服务器识别方法,其特征在于,所述预设阈值X可以根据所检测到的app数量、检测场景、误报率、和/或漏报率进行设置和调整。
7.根据权利要求1所述的移动应用隐私数据收集的第三方服务器识别方法,其特征在于,所述Android移动终端包括:智能手机、平板电脑、笔记本电脑、可穿戴智能设备、智能家电、车载智能终端、电纸书、PDA中的一种或多种。
8.一种用于移动应用隐私数据收集的第三方服务器识别的电子设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1-7中至少一项所述方法的步骤。
9.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1-7中至少一项所述方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110203313.7A CN112565306B (zh) | 2021-02-24 | 2021-02-24 | 一种app隐私数据收集的第三方服务器识别方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110203313.7A CN112565306B (zh) | 2021-02-24 | 2021-02-24 | 一种app隐私数据收集的第三方服务器识别方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN112565306A CN112565306A (zh) | 2021-03-26 |
CN112565306B true CN112565306B (zh) | 2021-05-14 |
Family
ID=75034590
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110203313.7A Active CN112565306B (zh) | 2021-02-24 | 2021-02-24 | 一种app隐私数据收集的第三方服务器识别方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112565306B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114647850A (zh) * | 2022-03-28 | 2022-06-21 | 重庆长安汽车股份有限公司 | 车载app隐私合规测试装置、方法、计算机设备及存储介质 |
Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104102358A (zh) * | 2014-07-18 | 2014-10-15 | 北京奇虎科技有限公司 | 隐私信息保护的方法及隐私信息保护装置 |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10163112B2 (en) * | 2016-07-14 | 2018-12-25 | International Business Machines Corporation | Assessing penalties for SDKs that violate policies in mobile apps |
CN107707721B (zh) * | 2017-11-06 | 2020-11-24 | Oppo广东移动通信有限公司 | 移动终端的录音方法、装置、存储介质及移动终端 |
CN110727952A (zh) * | 2019-08-30 | 2020-01-24 | 国家计算机网络与信息安全管理中心 | 一种移动应用程序第三方库隐私收集辨识方法 |
-
2021
- 2021-02-24 CN CN202110203313.7A patent/CN112565306B/zh active Active
Patent Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104102358A (zh) * | 2014-07-18 | 2014-10-15 | 北京奇虎科技有限公司 | 隐私信息保护的方法及隐私信息保护装置 |
Also Published As
Publication number | Publication date |
---|---|
CN112565306A (zh) | 2021-03-26 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN105825138B (zh) | 一种敏感数据识别的方法和装置 | |
CN106572117B (zh) | 一种WebShell文件的检测方法和装置 | |
CN105787366A (zh) | 基于组件关系的安卓软件可视化安全分析方法 | |
CN113111951B (zh) | 数据处理方法以及装置 | |
CN104640105B (zh) | 手机病毒分析和威胁关联的方法和系统 | |
CN111783092B (zh) | 面向安卓应用程序间通信机制的恶意攻击检测方法及系统 | |
CN105825129A (zh) | 一种融合通信中恶意软件鉴别方法和系统 | |
CN109815702B (zh) | 软件行为的安全检测方法、装置及设备 | |
CN111049828B (zh) | 网络攻击检测及响应方法及系统 | |
CN112565306B (zh) | 一种app隐私数据收集的第三方服务器识别方法 | |
CN119316226B (zh) | 一种终端非法外联的检测方法、装置及存储介质 | |
CN109684863A (zh) | 数据防泄漏方法、装置、设备及存储介质 | |
CN114915974A (zh) | 垃圾短信防治方法及装置 | |
CN103279708A (zh) | 一种移动终端恶意代码行为监控和分析的方法及系统 | |
CN114168423A (zh) | 异常号码的呼叫监控方法、装置、设备及存储介质 | |
Wongwiwatchai et al. | Comprehensive detection of vulnerable personal information leaks in android applications | |
CN110224975B (zh) | Apt信息的确定方法及装置、存储介质、电子装置 | |
CN108427882B (zh) | 基于行为特征抽取的安卓软件动态分析检测法 | |
TW202205116A (zh) | 察覺惡意攻擊的方法及網路安全管理裝置 | |
CN109271781B (zh) | 一种基于内核的应用程序获取超级权限行为检测方法与系统 | |
CN114826732B (zh) | 一种安卓系统隐私窃取行为的动态检测与溯源方法 | |
CN112688947B (zh) | 基于互联网的网络通信信息智能监测方法及系统 | |
CN112541183B (zh) | 数据处理方法及装置、边缘计算设备、存储介质 | |
CN115795475A (zh) | 软件系统风险的确定方法、装置及电子设备 | |
CN104363256B (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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant | ||
TR01 | Transfer of patent right | ||
TR01 | Transfer of patent right |
Effective date of registration: 20211119 Address after: Room 1019, 28 ningshuang Road, Yuhuatai District, Nanjing, Jiangsu 210012 Patentee after: Jiangsu Testing and Certification Co.,Ltd. Patentee after: Nanjing Institute of product quality supervision and inspection Address before: Room 1019, 28 ningshuang Road, Yuhuatai District, Nanjing, Jiangsu 210012 Patentee before: Jiangsu Testing and Certification Co.,Ltd. |