hacktricks/mobile-pentesting/android-app-pentesting
2024-01-10 06:29:36 +00:00
..
drozer-tutorial Translated ['mobile-pentesting/android-app-pentesting/drozer-tutorial/RE 2023-08-27 20:07:13 +00:00
frida-tutorial Translated ['README.md', 'backdoors/salseo.md', 'cryptography/certificat 2024-01-10 06:29:36 +00:00
adb-commands.md Translated ['linux-unix/privilege-escalation/docker-breakout.md', 'linux 2024-01-06 23:36:06 +00:00
android-applications-basics.md Translated ['macos-hardening/macos-security-and-privilege-escalation/mac 2024-01-05 11:51:55 +00:00
android-burp-suite-settings.md Translated ['README.md', 'backdoors/salseo.md', 'cryptography/certificat 2023-09-28 19:47:23 +00:00
android-task-hijacking.md Translated ['generic-methodologies-and-resources/exfiltration.md', 'gene 2023-09-03 01:34:43 +00:00
apk-decompilers.md Translated to Chinese 2023-08-03 19:12:22 +00:00
avd-android-virtual-device.md Translated ['mobile-pentesting/android-app-pentesting/README.md', 'mobil 2023-10-05 10:14:09 +00:00
bypass-biometric-authentication-android.md Translated ['linux-hardening/privilege-escalation/docker-security/docker 2023-12-19 21:55:08 +00:00
content-protocol.md Translated ['linux-unix/privilege-escalation/docker-breakout.md', 'linux 2024-01-06 23:36:06 +00:00
exploiting-a-debuggeable-applciation.md Translated to Chinese 2023-08-03 19:12:22 +00:00
google-ctf-2018-shall-we-play-a-game.md Translated to Chinese 2023-08-03 19:12:22 +00:00
inspeckage-tutorial.md Translated ['linux-unix/privilege-escalation/docker-breakout.md', 'linux 2024-01-06 23:36:06 +00:00
install-burp-certificate.md Translated ['README.md', 'backdoors/salseo.md', 'cryptography/certificat 2024-01-10 06:29:36 +00:00
intent-injection.md Translated ['linux-unix/privilege-escalation/docker-breakout.md', 'linux 2024-01-06 23:36:06 +00:00
make-apk-accept-ca-certificate.md Translated ['linux-unix/privilege-escalation/docker-breakout.md', 'linux 2024-01-06 23:36:06 +00:00
manual-deobfuscation.md Translated ['linux-unix/privilege-escalation/docker-breakout.md', 'linux 2024-01-06 23:36:06 +00:00
react-native-application.md Translated to Chinese 2023-08-03 19:12:22 +00:00
README.md Translated ['mobile-pentesting/android-app-pentesting/README.md', 'mobil 2023-10-05 10:14:09 +00:00
reversing-native-libraries.md Translated ['mobile-pentesting/android-app-pentesting/reversing-native-l 2023-12-24 18:22:05 +00:00
smali-changes.md Translated ['mobile-pentesting/android-app-pentesting/smali-changes.md'] 2023-10-11 21:33:30 +00:00
spoofing-your-location-in-play-store.md Translated to Chinese 2023-08-03 19:12:22 +00:00
tapjacking.md Translated ['mobile-pentesting/android-app-pentesting/README.md', 'mobil 2023-08-25 14:04:31 +00:00
webview-attacks.md Translated ['linux-hardening/privilege-escalation/docker-security/docker 2023-12-19 21:55:08 +00:00

Android应用程序渗透测试

☁️ HackTricks云 ☁️ -🐦 推特 🐦 - 🎙️ Twitch 🎙️ - 🎥 YouTube 🎥

HackenProof是所有加密漏洞赏金的家园。

即时获得奖励
HackenProof的赏金只有在客户存入奖励预算后才会启动。在漏洞经过验证后您将获得奖励。

在web3渗透测试中积累经验
区块链协议和智能合约是新的互联网在其崛起的日子里掌握web3安全。

成为web3黑客传奇
每次验证的漏洞都会获得声望积分,并登上每周排行榜的榜首。

在HackenProof上注册开始从您的黑客行动中获利!

{% embed url="https://hackenproof.com/register" %}

Android应用程序基础知识

强烈建议阅读此页面了解与Android安全相关的最重要的部分和Android应用程序中最危险的组件

{% content-ref url="android-applications-basics.md" %} android-applications-basics.md {% endcontent-ref %}

ADBAndroid调试桥

这是您连接到Android设备模拟或物理所需的主要工具。
它允许您通过USB网络从计算机上控制设备,复制文件来回,安装和卸载应用程序,运行shell命令,执行备份,读取日志等等。

请查看以下ADB命令列表了解如何使用adb。

Smali

有时候,修改应用程序代码以访问隐藏信息可能是混淆良好的密码或标志是很有趣的。然后将apk反编译修改代码并重新编译可能是有趣的。
在本教程中您可以学习如何反编译APK修改Smali代码并重新编译APK,以添加新功能。这在动态分析期间作为替代方案可能非常有用。因此,始终记住这种可能性

其他有趣的技巧

adb shell pm list packages
com.android.insecurebankv2

adb shell pm path com.android.insecurebankv2
package:/data/app/com.android.insecurebankv2-Jnf8pNgwy3QA_U5f-n_4jQ==/base.apk

adb pull /data/app/com.android.insecurebankv2- Jnf8pNgwy3QA_U5f-n_4jQ==/base.apk

静态分析

首先要分析一个APK你应该使用反编译工具来查看Java代码。请在这里阅读有关不同可用反编译工具的信息

寻找有趣的信息

只需查看APK的字符串您就可以搜索密码、URLhttps://github.com/ndelphit/apkurlgrep、API密钥、加密、蓝牙UUID、令牌和任何有趣的内容...甚至查找代码执行后门或身份验证后门(硬编码的管理员凭据)。

Firebase

特别注意Firebase的URL并检查其是否配置错误。在这里了解有关Firebase是什么以及如何利用它的更多信息。

对应用程序的基本理解 - Manifest.xmlstrings.xml

使用任何在这里提到的反编译工具之一您将能够阅读Manifest.xml。您还可以将apk文件扩展名重命名为.zip并解压缩它。通过阅读清单您可以找到以下漏洞

  • 首先检查应用程序是否可调试。生产APK不应该是可调试的否则其他人将能够连接到它。您可以在清单中查找属性debuggable="true"来检查应用程序是否可调试。示例:<application theme="@2131296387" debuggable="true"
  • 在这里学习如何在手机上查找可调试的应用程序并利用它们
  • 备份android:allowBackup属性定义了用户启用USB调试后是否可以备份和恢复应用程序数据。如果备份标志设置为true则允许攻击者通过adb备份应用程序数据即使设备未root。因此处理和存储敏感信息如卡片详细信息、密码等的应用程序应将此设置显式设置为false因为默认情况下它设置为true以防止此类风险。
  • <application android:allowBackup="false"
  • NetworkSecurity:应用程序的网络安全性可以使用android:networkSecurityConfig="@xml/network_security_config"覆盖默认值。可以在res/xml中放置一个名为network_security_config的文件。此文件将配置重要的安全设置如证书固定或是否允许HTTP流量。您可以在这里阅读有关可以配置的所有内容的更多信息但请查看以下示例了解如何为某些域配置HTTP流量
  • <domain-config cleartextTrafficPermitted="true"> <domain includeSubdomains="true">formation-software.co.uk </domain></domain-config>
  • 导出的活动:检查清单中导出的活动,因为这可能是危险的。稍后在动态分析中,将解释如何利用此行为
  • 内容提供程序:如果公开了一个导出的提供程序,您可能能够访问/修改有趣的信息。在动态分析中,您将学习如何滥用它们
  • 检查android:name="android.support.FILE_PROVIDER_PATHS"属性中的FileProviders配置。在这里阅读有关FileProviders的更多信息
  • 公开的服务:根据服务在内部执行的操作,可能会存在漏洞。在动态分析中,您将学习如何滥用它们
  • 广播接收器您将学习如何可能利用它们在动态分析中。
  • URL方案:阅读管理方案的活动代码,并查找处理用户输入的漏洞。有关URL方案的更多信息请点击此处
  • minSdkVersiontargetSDKVersionmaxSdkVersion它们指示应用程序将在哪些Android版本上运行。从安全角度来看支持旧版本将允许已知的Android漏洞版本运行。

通过阅读resources.arsc/strings.xml,您可以找到一些有趣的信息:

  • API密钥
  • 自定义模式
  • 开发人员在此文件中保存的其他有趣信息

Tapjacking

Tapjacking是一种攻击,其中一个恶意应用程序被启动并位于受害者应用程序的顶部。一旦它遮挡了受害者应用程序,它的用户界面被设计成以一种方式欺骗用户与之交互,同时将交互传递给受害者应用程序。实际上,它使用户无法知道他们实际上是在对受害者应用程序执行操作。

在以下链接中查找更多信息:

{% content-ref url="tapjacking.md" %} tapjacking.md {% endcontent-ref %}

任务劫持

将**launchMode设置为singleTask且未定义任何taskAffinity活动容易受到任务劫持的攻击。这意味着,可以安装一个应用程序**,如果在真正的应用程序之前启动它,它可以劫持真正应用程序的任务(因此用户将与恶意应用程序交互,而以为自己在使用真正的应用程序)。

更多信息请参见:

{% content-ref url="android-task-hijacking.md" %} android-task-hijacking.md {% endcontent-ref %}

不安全的数据存储

内部存储

内部存储上创建的文件仅由应用程序访问。这种保护是由Android实现的对于大多数应用程序来说已经足够。但是开发人员经常使用MODE_WORLD_READBALEMODE_WORLD_WRITABLE将这些文件的访问权限授予其他应用程序,但这并不限制其他应用程序(恶意应用程序)访问它们。在静态分析期间,检查是否使用了这些模式,在动态分析期间,检查创建的文件的权限(也许其中一些是全球可读/可写的)。 在这里了解有关此漏洞及如何修复它的更多信息。

外部存储

外部存储如SD卡上创建的文件是全局可读和可写的。由于外部存储可以被用户移除并且可以被任何应用程序修改,您不应该使用外部存储来存储敏感信息。与来自任何不受信任的来源的数据一样,处理来自外部存储的数据时,应进行输入验证。我们强烈建议在动态加载之前不要将可执行文件或类文件存储在外部存储上。如果您的应用程序确实从外部存储检索可执行文件,则应在动态加载之前对文件进行签名和加密验证。 信息来源:点击此处

可以在/storage/emulated/0/sdcard/mnt/sdcard中访问外部存储。

{% hint style="info" %} 从Android 4.4API 17开始SD卡具有目录结构限制应用程序对特定应用程序的目录的访问。这样可以防止恶意应用程序读取或写入另一个应用程序的文件。 {% endhint %}

明文存储的敏感数据

  • 共享首选项Android允许每个应用程序轻松保存xml文件在路径/data/data/<packagename>/shared_prefs/中,有时可以在该文件夹中找到明文存储的敏感

破损的TLS

接受所有证书

由于某种原因,有时开发人员会接受所有证书,即使主机名与以下代码行不匹配,例如:

SSLSocketFactory sf = new cc(trustStore);
sf.setHostnameVerifier(SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);

一种测试的好方法是尝试使用像Burp这样的代理来捕获流量而不需要在设备内授权Burp CA。此外您可以使用Burp生成一个针对不同主机名的证书并使用它。

加密破解

密钥管理流程不佳

一些开发人员将敏感数据保存在本地存储中,并使用在代码中硬编码/可预测的密钥进行加密。这样做是不应该的,因为一些逆向工程可能会使攻击者提取机密信息。

使用不安全和/或已弃用的算法

开发人员不应使用已弃用的算法来执行授权检查存储发送数据。其中一些算法包括RC4、MD4、MD5、SHA1...如果用于存储密码的哈希值,应使用具有盐的哈希值来抵御暴力破解。

其他检查

  • 建议对APK进行混淆,以增加对逆向工程的阻碍。
  • 如果应用程序是敏感的如银行应用程序应该执行自己的检查以查看移动设备是否已经root并采取相应措施。
  • 如果应用程序是敏感的(如银行应用程序),应检查是否正在使用模拟器。
  • 如果应用程序是敏感的(如银行应用程序),应在执行之前检查自身的完整性,以检查是否已被修改。
  • 使用APKiD检查用于构建APK的编译器/打包器/混淆器

React Native应用程序

阅读以下页面了解如何轻松访问React应用程序的JavaScript代码

{% content-ref url="react-native-application.md" %} react-native-application.md {% endcontent-ref %}

Xamarin应用程序

阅读以下页面了解如何轻松访问Xamarin应用程序的C#代码:

{% content-ref url="../xamarin-apps.md" %} xamarin-apps.md {% endcontent-ref %}

超级打包应用程序

根据这篇博文,超级打包是一种将应用程序的内容压缩到单个文件中的元算法。该博文讨论了创建一个解压这些应用程序的应用程序的可能性...以及一种更快的方法,即执行应用程序并从文件系统中收集解压缩的文件

自动静态代码分析

工具mariana-trench能够通过扫描应用程序的代码来查找漏洞。该工具包含一系列已知源(指示工具用户控制的输入位置)、漏洞点(指示工具危险的位置,恶意用户输入可能会造成损害)和规则。这些规则指示了源-漏洞点的组合,表明存在漏洞。

有了这些知识,mariana-trench将审查代码并找出可能的漏洞

泄露的机密信息

应用程序中可能包含一些机密信息API密钥、密码、隐藏的URL、子域名...),您可能能够发现这些信息。您可以使用诸如https://github.com/dwisiswant0/apkleaks之类的工具。

绕过生物识别认证

{% content-ref url="bypass-biometric-authentication-android.md" %} bypass-biometric-authentication-android.md {% endcontent-ref %}

其他有趣的功能

  • 代码执行Runtime.exec(), ProcessBuilder(), native code:system()
  • 发送短信sendTextMessage, sendMultipartTestMessage
  • 声明为native本地函数public native, System.loadLibrary, System.load
  • 阅读此内容以了解如何逆向本地函数

其他技巧

{% content-ref url="content-protocol.md" %} content-protocol.md {% endcontent-ref %}


HackenProof是所有加密漏洞赏金的家园。

即时获得奖励
HackenProof的赏金只有在客户存入奖励预算后才会启动。在漏洞经过验证后您将获得奖励。

在web3渗透测试中积累经验
区块链协议和智能合约是新的互联网在其崛起之时掌握web3安全。

成为web3黑客传奇
每次验证的漏洞都会获得声誉积分,并占据每周排行榜的榜首。

在HackenProof上注册开始从您的黑客行动中获利!

{% embed url="https://hackenproof.com/register" %}


动态分析

首先您需要一个可以安装应用程序和所有环境主要是Burp CA证书、Drozer和Frida的环境。因此强烈建议使用已root的设备模拟或非模拟

在线动态分析

您可以在https://appetize.io/创建一个免费账户。该平台允许您上传执行APK文件因此可以用于查看APK的行为。

您甚至可以在网页上查看应用程序的日志并通过adb进行连接。

通过ADB连接您可以在模拟器中使用DrozerFrida

本地动态分析

使用模拟器

  • Android Studio(您可以创建x86arm设备,并根据此链接最新的x86版本支持ARM库无需使用缓慢的arm模拟器
  • 了解如何在此页面中设置它:

{% content-ref url="avd-android-virtual-device.md" %} avd-android-virtual-device.md {% endcontent-ref %}

  • Genymotion (免费版本:个人版,您需要创建一个账户。建议下载带有VirtualBox的版本以避免潜在错误。
  • Nox免费但不支持Frida或Drozer

{% hint style="info" %} 在任何平台上创建新模拟器时,请记住屏幕越大,模拟器运行得越慢。因此,如果可能,请选择小屏幕。 {% endhint %}

要在Genymotion中安装Google服务(如应用商店),您需要单击以下图像中标记为红色的按钮:

此外请注意在Genymotion中的Android VM配置中,您可以选择桥接网络模式如果您将从具有工具的不同VM连接到Android VM则这将非常有用

使用物理设备

您需要激活调试选项,如果可以root它会很好:

  1. 设置
  2. 从Android 8.0开始)选择系统
  3. 选择关于手机
  4. 连续按版本号7次。
  5. 返回,您将找到开发者选项

安装应用程序后,您首先应该尝试并调查它的功能,了解它的工作原理,并熟悉它。
我建议您使用MobSF动态分析+pidcat来执行此初始动态分析这样您就可以在MobSF捕获许多有趣的数据后进行学习,并稍后进行审查。

非预期的数据泄漏

日志记录

开发人员经常公开留下调试信息。因此,任何具有READ_LOGS权限的应用程序都可以通过它们访问这些日志,并可以通过这些日志获得敏感信息。
在浏览应用程序时,使用pidcat(推荐,更易于使用和阅读)或adb logcat来读取创建的日志,并寻找敏感信息

{% hint style="warning" %} 请注意,从Android 4.0的较新版本开始,应用程序只能访问自己的日志。因此,应用程序无法访问其他应用程序的日志。
无论如何,仍然建议不要记录敏感信息。 {% endhint %}

复制/粘贴缓存

Android提供了基于剪贴板的框架用于在Android应用程序中提供复制粘贴功能。但是当一些其他应用程序可以访问包含某些敏感数据的剪贴板时,这会导致严重问题。应该禁用应用程序的敏感部分复制/粘贴功能。例如,禁用复制信用卡详细信息。

崩溃日志

如果应用程序在运行时崩溃并将日志保存在某个地方那么这些日志对攻击者尤其有帮助特别是在无法对Android应用程序进行逆向工程的情况下。然后避免在应用程序崩溃时创建日志并且如果日志通过网络发送则确保它们通过SSL通道发送。
作为渗透测试人员,请尝试查看这些日志

发送给第三方的分析数据

大多数应用程序在其应用程序中使用其他服务例如Google Adsense但有时它们会泄漏一些敏感数据或不需要发送给该服务的数据。这可能是因为开发人员没有正确实现功能。您可以通过拦截应用程序的流量来查看是否向第三方发送了敏感数据

SQLite数据库

大多数应用程序将使用内部SQLite数据库保存信息。在渗透测试期间,查看创建的数据库的名称以及保存的所有数据,因为您可能会发现敏感信息(这将是一个漏洞)。
数据库应位于/data/data/the.package.name/databases,例如/data/data/com.mwr.example.sieve/databases

如果数据库保存了机密信息并且加密,但您可以在应用程序内找到密码,这仍然是一个漏洞

使用.tables枚举表,使用.schema <table_name>枚举表的列

Drozer利用活动、内容提供程序和服务

Drozer允许您扮演Android应用程序的角色并与其他应用程序交互。它可以执行已安装应用程序可以执行的任何操作例如利用Android的进程间通信IPC机制并与底层操作系统交互。详见Drozer指南
Drozer是一个有用的工具可以在接下来的章节中学习如何利用导出的活动、导出的服务和内容提供程序

利用导出的活动

如果您想回顾一下什么是Android活动请阅读此内容。
还要记住,活动的代码从onCreate方法开始。

绕过授权

当一个活动被导出时,您可以从外部应用程序调用其屏幕。因此,如果一个包含敏感信息的活动被导出,您可以绕过身份验证机制访问它
了解如何使用Drozer利用导出的活动。

您还可以使用adb启动导出的活动

  • 包名为com.example.demo
  • 导出的活动名为com.example.test.MainActivity
adb shell am start -n com.example.demo/com.example.test.MainActivity

注意MobSF会将在活动中使用android:launchMode作为singleTask/singleInstance的方法检测为恶意行为,但根据此链接的说明这只在旧版本API版本<21中存在危险。

{% hint style="info" %} 请注意,授权绕过并不总是漏洞,这取决于绕过的方式以及暴露的信息。 {% endhint %}

敏感信息泄露

活动也可以返回结果。如果您找到一个已导出且未受保护的活动调用了**setResult方法并返回敏感信息**,那么就存在敏感信息泄露。

Tapjacking

如果未防止tapjacking您可以滥用导出的活动来使用户执行意外操作。有关什么是Tapjacking的更多信息请点击此链接

利用内容提供程序 - 访问和操作敏感信息

如果您想回顾一下什么是内容提供程序,请阅读此内容。
内容提供程序基本上用于共享数据。如果应用程序有可用的内容提供程序,您可能能够从中提取敏感数据。还可以测试可能的SQL注入路径遍历,因为它们可能存在漏洞。
了解如何使用Drozer利用内容提供程序。

利用服务

如果您想回顾一下什么是服务,请阅读此内容。
请记住,服务的操作从onStartCommand方法开始。

服务基本上是可以接收数据处理它并返回(或不返回)响应的东西。因此,如果应用程序导出了一些服务,您应该检查代码以了解其功能,并动态测试以提取机密信息、绕过身份验证措施等...
了解如何使用Drozer利用服务。

利用广播接收器

如果您想回顾一下什么是广播接收器,请阅读此内容。
请记住,广播接收器的操作从onReceive方法开始。

广播接收器将等待某种类型的消息。根据接收器处理消息的方式,它可能存在漏洞。
了解如何使用Drozer利用广播接收器。

您可以手动查找深层链接使用像MobSF这样的工具或像这个的脚本。
您可以使用adb浏览器打开已声明的scheme

{% code overflow="wrap" %}

adb shell am start -a android.intent.action.VIEW -d "scheme://hostname/path?param=value" [your.package.name]

{% endcode %}

请注意,您可以省略包名,手机将自动调用应该打开该链接的应用程序。

{% code overflow="wrap" %}

<!-- Browser regular link -->
<a href="scheme://hostname/path?param=value">Click me</a>
<!-- fallback in your url you could try the intent url -->
<a href="intent://hostname#Intent;scheme=scheme;package=your.package.name;S.browser_fallback_url=http%3A%2F%2Fwww.example.com;end">with alternative</a>

{% endcode %}

执行的代码

为了找到在应用程序中执行的代码,请转到由深度链接调用的活动,并搜索函数onNewIntent

敏感信息

每次找到一个深度链接时请检查它是否通过URL参数接收敏感数据如密码因为任何其他应用程序都可以冒充深度链接并窃取这些数据

路径中的参数

您还必须检查任何深度链接是否在URL的路径中使用参数例如https://api.example.com/v1/users/{username},在这种情况下,您可以通过访问example://app/users?username=../../unwanted-endpoint%3fparam=value来强制进行路径遍历。请注意,如果您在应用程序中找到正确的端点,您可能能够引发开放重定向(如果路径的一部分用作域名),账户劫持如果您可以在没有CSRF令牌的情况下修改用户详细信息并且漏洞端点使用了正确的方法和其他任何漏洞。有关此的更多信息请参见此处

更多示例

有关链接的一个有趣的赏金漏洞报告/.well-known/assetlinks.json)。

不足的传输层保护

  • **缺乏证书检查:**Android应用程序未能验证呈现给它的证书的身份。大多数应用程序会忽略警告并接受任何自签名证书。而有些应用程序则通过HTTP连接传递流量。
  • **弱握手协商:**应用程序和服务器进行了SSL/TLS握手但使用了容易受到中间人攻击的不安全密码套件。因此任何攻击者都可以轻松解密该连接。
  • **隐私信息泄露:**大多数情况下应用程序通过安全通道进行身份验证但其余的连接都是通过非安全通道进行的。这并不增加应用程序的安全性因为其余的敏感数据如会话cookie或用户数据可以被恶意用户拦截。

从所提供的3种情况中我们将讨论如何验证证书的身份。另外两种情况取决于服务器的TLS配置以及应用程序是否发送未加密的数据。渗透测试人员应该自行检查服务器的TLS配置此处)并检测是否通过未加密/易受攻击的通道发送了任何机密信息。有关如何发现和修复此类漏洞的更多信息,请参见此处

SSL Pinning

默认情况下在进行SSL连接时客户端Android应用程序会检查服务器的证书是否具有可验证的信任链并与请求的主机名匹配。这导致了中间人攻击MITM的问题。
在证书固定中Android应用程序本身包含服务器的证书并且只有在呈现相同证书时才传输数据。
建议在将发送敏感信息的站点上
应用SSL Pinning

检查HTTP流量

首先,您应该(必须)安装您将使用的代理工具可能是Burp的证书。如果您不安装代理工具的CA证书您可能无法在代理中看到加密的流量。
阅读此指南以了解如何安装自定义CA证书

对于针对API Level 24+的应用程序仅安装Burp CA证书在设备上是不够的。要绕过此新保护您需要修改网络安全配置文件。因此您可以修改此文件以授权您的CA证书或者您可以阅读此页面以了解如何强制应用程序再次接受设备中安装的所有证书

SSL Pinning

我们已经在2段之前讨论了什么是SSL Pinning。当它在应用程序中实施时您需要绕过它以检查HTTPS流量否则您将无法看到它。
这里我将介绍一些我用来绕过此保护的选项:

常见的Web漏洞

请注意在此步骤中您应该寻找常见的Web漏洞。关于Web漏洞的大量信息可以在本书中找到因此我不会在此处提及它们。

Frida

用于开发人员、逆向工程师和安全研究人员的动态插装工具包。了解更多信息,请访问www.frida.re
它非常强大,您可以访问正在运行的应用程序并在运行时挂钩方法以更改行为、更改值、提取值、运行不同的代码...
如果您想进行Android应用程序渗透测试您需要知道如何使用Frida。

学习如何使用FridaFrida教程
一些用于与Frida执行操作的“GUI”https://github.com/m0bilesecurity/RMS-Runtime-Mobile-Security
基于Frida的其他一些抽象https://github.com/sensepost/objectionhttps://github.com/dpnishant/appmon
您可以在此处找到一些很棒的Frida脚本https://codeshare.frida.re/

转储内存 - Fridump

检查应用程序是否在内存中存储了不应该存储的敏感信息,如密码或助记词。

使用Fridump3,您可以通过以下方式转储应用程序的内存:

# With PID
python3 fridump3.py -u <PID>

# With name
frida-ps -Uai
python3 fridump3.py -u "<Name>"

这将在./dump文件夹中转储内存然后您可以使用类似以下命令进行grep搜索

{% code overflow="wrap" %}

strings * | grep -E "^[a-z]+ [a-z]+ [a-z]+ [a-z]+ [a-z]+ [a-z]+ [a-z]+ [a-z]+ [a-z]+ [a-z]+ [a-z]+ [a-z]+$"

{% endcode %}

Keystore中的敏感数据

在Android中Keystore是存储敏感数据的最佳位置然而具备足够权限的情况下仍然有可能访问它。由于应用程序倾向于在此处以明文形式存储敏感数据因此渗透测试应该以root用户或者具有物理访问设备权限的人员身份检查它否则可能会导致数据被窃取。

即使应用程序将数据存储在Keystore中数据也应该进行加密。

要访问Keystore中的数据您可以使用以下Frida脚本https://github.com/WithSecureLabs/android-keystore-audit/blob/master/frida-scripts/tracer-cipher.js

frida -U -f com.example.app -l frida-scripts/tracer-cipher.js

指纹/生物识别绕过

使用以下Frida脚本可能可以绕过Android应用程序执行的指纹认证以保护某些敏感区域

{% code overflow="wrap" %}

frida --codeshare krapgras/android-biometric-bypass-update-android-11 -U -f <app.package>

{% endcode %}

背景图片

当你将一个应用程序放在后台时Android会存储该应用程序的快照,以便在恢复到前台时,它会在应用程序之前加载图像,使得应用程序看起来加载得更快。

然而,如果这个快照包含敏感信息,那么有权访问快照的人可能会窃取这些信息请注意您需要root权限才能访问

这些快照通常存储在:/data/system_ce/0/snapshots

Android提供了一种方法来通过设置FLAG_SECURE布局参数来防止截屏。通过使用此标志,窗口内容被视为安全,防止其出现在截屏中或在非安全显示器上查看。

getWindow().setFlags(LayoutParams.FLAG_SECURE, LayoutParams.FLAG_SECURE);

Android应用程序分析器

这个工具可以帮助您在动态分析过程中管理不同的工具:https://github.com/NotSoSecure/android_application_analyzer

Intent注入

这个漏洞类似于Web安全中的开放重定向。由于Intent类是Parcelable的,属于这个类的对象可以作为额外的数据传递给另一个Intent对象。
许多开发人员利用这个特性创建代理组件(活动、广播接收器和服务),将其嵌入的Intent传递给startActivity(...)sendBroadcast(...)等危险方法。
这是危险的,因为攻击者可以强制应用启动一个不能直接从另一个应用程序启动的非导出组件,或者授予攻击者访问其内容提供程序的权限。**WebView有时也会将URL从字符串转换为Intent**对象,使用Intent.parseUri(...)方法,并将其传递给startActivity(...)

Android客户端注入和其他漏洞

可能您已经从Web中了解过这种漏洞。在Android应用程序中您必须特别注意以下漏洞

  • **SQL注入**在处理动态查询或内容提供程序时,请确保使用参数化查询。
  • **JavaScript注入XSS**验证任何WebView是否已禁用JavaScript和插件支持默认禁用更多信息请点击此处
  • **本地文件包含:**验证任何WebView是否已禁用文件系统访问默认启用webview.getSettings().setAllowFileAccess(false);更多信息请点击此处
  • **永久cookie**在某些情况下当Android应用程序结束会话时cookie不会被撤销甚至可能保存到磁盘上。
  • cookie中的Secure标志

HackenProof是所有加密漏洞赏金的家园。

即时获得奖励
HackenProof的赏金只有在客户存入奖励预算后才会启动。在漏洞经过验证后您将获得奖励。

在web3渗透测试中积累经验
区块链协议和智能合约是新的互联网在其兴起的日子里掌握web3安全。

成为web3黑客传奇
每次验证的漏洞都会获得声誉积分,并占据每周排行榜的榜首。

在HackenProof上注册开始从您的黑客攻击中获利!

{% embed url="https://hackenproof.com/register" %}

自动分析

MobSF

静态分析

使用一个漂亮的基于Web的前端对应用程序进行漏洞评估。您还可以执行动态分析(但需要准备环境)。

docker pull opensecurity/mobile-security-framework-mobsf
docker run -it -p 8000:8000 opensecurity/mobile-security-framework-mobsf:latest

请注意MobSF可以分析AndroidapkIOSipaWindowsapx应用程序Windows应用程序必须从安装在Windows主机上的MobSF进行分析)。此外,如果您创建了一个包含AndroidIOS应用程序源代码的ZIP文件转到应用程序的根文件夹选择所有内容并创建ZIP文件MobSF也可以分析它。

MobSF还允许您进行差异/比较分析,并集成VirusTotal您需要在_MobSF/settings.py_中设置API密钥并启用它VT_ENABLED = TRUE VT_API_KEY = <Your API key> VT_UPLOAD = TRUE)。您还可以将VT_UPLOAD设置为False,然后将上传哈希而不是文件。

使用MobSF进行辅助动态分析

对于Android动态分析MobSF也非常有帮助但在这种情况下您需要在主机上安装MobSF和genymotion虚拟机或Docker不起作用注意:您需要先启动genymotion中的虚拟机然后再启动MobSF。
MobSF动态分析器可以

  • 转储应用程序数据URL、日志、剪贴板、您创建的截图、由“导出的Activity测试器”创建的截图、电子邮件、SQLite数据库、XML文件和其他创建的文件。除了截图外所有这些都是自动完成的您需要在需要截图时按下按钮或者按下“导出的Activity测试器”以获取所有导出活动的截图。
  • 捕获HTTPS流量
  • 使用Frida获取运行时信息

Android版本> 5开始,它将自动启动Frida并设置全局代理设置以捕获流量。它只会捕获被测试应用程序的流量。

Frida

默认情况下它还使用一些Frida脚本来绕过SSL证书固定检测Root检测调试器,以及监视有趣的API
MobSF还可以调用导出的活动,抓取它们的截图并将它们保存到报告中。

要开始动态测试,请按下绿色按钮:“开始仪器化”。按下“Frida实时日志”以查看Frida脚本生成的日志按下“实时API监视器”以查看所有被挂钩方法的调用、传递的参数和返回值(在按下“开始仪器化”后出现)。
MobSF还允许您加载自己的Frida脚本要将Friday脚本的结果发送到MobSF请使用函数send())。它还有几个预写的脚本可以加载(您可以在MobSF/DynamicAnalyzer/tools/frida_scripts/others/中添加更多),只需选择它们,按下“加载”,然后按下“开始仪器化”(您将能够在“Frida实时日志”中看到该脚本的日志)。

此外您还有一些辅助的Frida功能

  • 枚举已加载的类:它将打印所有已加载的类
  • 捕获字符串:在使用应用程序时,它将打印所有捕获的字符串(非常嘈杂)
  • 捕获字符串比较:可能非常有用。它将显示正在比较的两个字符串以及结果是True还是False。
  • 枚举类方法输入类名如“java.io.File”它将打印类的所有方法。
  • 搜索类模式:按模式搜索类
  • 跟踪类方法跟踪整个类查看类的所有方法的输入和输出。请记住默认情况下MobSF跟踪几个有趣的Android Api方法。

选择要使用的辅助模块后,需要按下“开始仪器化”,然后您将在“Frida实时日志”中看到所有输出。

Shell

Mobsf还为您提供了一个带有一些adb命令、MobSF命令和常见shell命令的shell位于动态分析页面的底部。一些有趣的命令

help
shell ls
activities
exported_activities
services
receivers

HTTP工具

当捕获到HTTP流量时你可以在“HTTP(S) Traffic”底部看到捕获到的流量的不美观视图,或者在“Start HTTPTools”绿色按钮中看到更好的视图。从第二个选项开始你可以将捕获到的请求发送到Burp或Owasp ZAP等代理服务器。
要这样做,启动Burp --> 关闭拦截 --> 在MobSB HTTPTools中选择请求 --> 按下“Send to Fuzzer” --> 选择代理地址 (http://127.0.0.1:8080\)。

在使用MobSF进行动态分析后你可以点击“Start Web API Fuzzer”来对HTTP请求进行模糊测试并寻找漏洞。

{% hint style="info" %} 在使用MobSF进行动态分析后代理设置可能会配置错误你将无法通过GUI修复它们。你可以通过以下方式修复代理设置

adb shell settings put global http_proxy :0

{% endhint %}

使用Inspeckage进行辅助动态分析

您可以从Inspeckage获取该工具。
该工具使用一些Hooks,让您了解在您进行动态分析时应用程序中发生了什么。

{% content-ref url="inspeckage-tutorial.md" %} inspeckage-tutorial.md {% endcontent-ref %}

Yaazhini

这是一个用于带有GUI的静态分析的优秀工具

Qark

该工具旨在查找几种与安全相关的Android应用程序漏洞无论是在源代码还是打包的APK中。该工具还能够创建一个“Proof-of-Concept”可部署的APK和ADB命令以利用找到的一些漏洞暴露的活动、意图、tapjacking等。与Drozer一样无需对测试设备进行root操作。

pip3 install --user qark  # --user is only needed if not using a virtualenv
qark --apk path/to/my.apk
qark --java path/to/parent/java/folder
qark --java path/to/specific/java/file.java

ReverseAPK

  • 显示所有提取的文件以便参考
  • 自动将APK文件反编译为Java和Smali格式
  • 分析AndroidManifest.xml以查找常见的漏洞和行为
  • 静态源代码分析以查找常见的漏洞和行为
  • 设备信息
  • 意图
  • 命令执行
  • SQLite引用
  • 日志引用
  • 内容提供者
  • 广播接收器
  • 服务引用
  • 文件引用
  • 加密引用
  • 硬编码的秘密
  • URL
  • 网络连接
  • SSL引用
  • WebView引用
reverse-apk relative/path/to/APP.apk

SUPER Android Analyzer

SUPER是一个命令行应用程序可在Windows、MacOS X和Linux上使用用于分析_.apk_文件以寻找漏洞。它通过解压APK并应用一系列规则来检测这些漏洞。

所有规则都集中在一个rules.json文件中,每个公司或测试人员都可以创建自己的规则来分析他们所需的内容。

下载页面下载最新的二进制文件。

super-analyzer {apk_file}

StaCoAn

StaCoAn是一个跨平台工具,可帮助开发人员、漏洞赏金猎人和道德黑客对移动应用程序进行静态代码分析

其概念是您将移动应用程序文件(.apk或.ipa文件拖放到StaCoAn应用程序上它将为您生成一个可视化和便携的报告。您可以调整设置和词汇表以获得定制化的体验。

下载最新版本

./stacoan

AndroBugs

AndroBugs框架是一个Android漏洞分析系统帮助开发者或黑客发现Android应用中的潜在安全漏洞。
Windows版本

python androbugs.py -f [APK file]
androbugs.exe -f [APK file]

Androwarn

Androwarn 是一个工具,其主要目的是检测并警告用户有关 Android 应用程序可能存在的恶意行为。

该工具通过对应用程序的 Dalvik 字节码进行静态分析来进行检测,字节码以 Smali 形式表示,并使用 androguard 库。

该工具寻找“坏”应用程序的常见行为,例如:泄露电话标识符、拦截音视频流、修改 PIM 数据、任意代码执行等。

python androwarn.py -i my_application_to_be_analyzed.apk -r html -v 3

MARA Framework

MARA 是一个移动应用程序逆向工程和分析框架。它是一个将常用的移动应用程序逆向工程和分析工具集合在一起的工具用于测试移动应用程序的OWASP移动安全威胁。其目标是使移动应用程序开发人员和安全专业人员更容易和友好地完成这项任务。

它能够:

Koodous

用于检测恶意软件:https://koodous.com/

代码混淆/反混淆

请注意,根据您用于混淆代码的服务和配置,秘密信息可能会被混淆或未被混淆。

ProGuard

ProGuard 是一个开源的命令行工具用于缩小、优化和混淆Java代码。它能够优化字节码并检测和删除未使用的指令。ProGuard是免费软件根据GNU通用公共许可证第2版分发。

ProGuard作为Android SDK的一部分分发并在发布模式下构建应用程序时运行。

来源:https://en.wikipedia.org/wiki/ProGuard_(software)

DexGuard

https://blog.lexfo.fr/dexguard.html中找到了一个逐步指南来反混淆APK

来自该指南我们上次检查时Dexguard的操作模式是

  • 将资源作为InputStream加载
  • 将结果提供给继承自FilterInputStream的类以进行解密
  • 进行一些无用的混淆,以浪费逆向工程师的几分钟时间;
  • 将解密后的结果提供给ZipInputStream以获取DEX文件
  • 最后使用loadDex方法将生成的DEX作为资源加载。

DeGuard

DeGuard 反混淆了Android混淆工具执行的混淆过程。这使得可以进行多种安全分析包括代码检查和预测库。

您可以将混淆的APK上传到他们的平台。

Simplify

它是一个通用的Android反混淆器。Simplify 虚拟执行一个应用程序以了解其行为,然后尝试优化代码,使其行为相同但更容易理解。每种优化类型都是简单和通用的,因此不管使用的具体混淆类型是什么都没有关系。

APKiD

APKiD提供有关APK的制作方式的信息。它可以识别许多编译器打包工具混淆工具和其他奇怪的东西。它是Android的PEiD

手动

阅读此教程以了解一些关于如何反向自定义混淆的技巧

实验室

Androl4b

AndroL4b是一个基于ubuntu-mate的Android安全虚拟机包括来自不同安全极客和研究人员的最新框架、教程和实验室用于逆向工程和恶意软件分析。

OWASP

{% embed url="https://github.com/OWASP/owasp-mstg%0Ahttps://mobile-security.gitbook.io/mobile-security-testing-guide/ios-testing-guide/0x06g-testing-network-communication" %}

Git Repos

https://github.com/riddhi-shree/nullCommunity/tree/master/Android
https://www.youtube.com/watch?v=PMKnPaGWxtg&feature=youtu.be&ab_channel=B3nacSec

参考资料

了解更多信息,请访问:

测试

HackenProof 是所有加密漏洞赏金的家园。

即刻获得奖励
HackenProof 的赏金只有在客户存入奖励预算后才会启动。在漏洞经过验证后,您将获得奖励。

在 web3 渗透测试中积累经验
区块链协议和智能合约是新的互联网!掌握 web3 安全的崛起时刻。

成为 web3 黑客传奇
每次验证的漏洞都会获得声誉积分,并登上每周排行榜的榜首。

在 HackenProof 上注册 开始从您的黑客行动中获利!

{% embed url="https://hackenproof.com/register" %}

☁️ HackTricks Cloud ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥