安全测试工具(连载9)

简介: 安全测试工具(连载9)

4 APP反向编译工具


APP反向编译工具是APP安全领域很重要的工具,本节介绍Dex2jar、和jd-gui。秀一节介绍apktool

  • Dex2jar:是把.apk文件反向转换为.jar文件。
  • Proguard:是AndroidSDK自带的jar文件混淆器软件。
  • jd-gui:是一个基于JAVA GUI界面的转换jar文件成JAVA源代码的工具。
  • apktool:是一款集成了android apk编译、转换签名文件、smali文件编辑等功能于一体的软件。


4.1Dex2jar、Proguard和jd-gui

1. apk文件反编译

首先进入dex2jar目录,把apk文件从手机中取下来(demo4.apk为反编译的apk文件)。

C:\Users\xiang>cd c:\dex2jar-2.0

C:\dex2jar-2.0>adb pull /data/app/demo4.apk


      使用下面命令,把apk文件反编译成jar文件。

C:\dex2jar-2.0>d2j-dex2jar demo4.apk

dex2jar demo4.apk -> .\demo4-dex2jar.jar


      然后通过jd-gui工具查看JAVA源代码(jd-gui下载后也放在Dex2jar目录下),如45所示。


C:\dex2jar-2.0>jd-gui demo4-dex2jar.jar


image.png

45 jd-gui展示反编译jar文件的JAVA源码

2. 使用Proguard工具进行混淆

      AndroidSDK工具目录下%SDK_HOME%\tools\自带Proguard工具,但是一般而言版本比较低,建议在网上下载最新版本,放在%SDK_HOME%\tools\目录下,本书使用的是V6.1.1版本。


      进入%SDK_HOME%\tools\proguard6.1.1\bin\,启动proguardgui.bat,点击【Load configuration】按键,选择Android SDK工具目录下%SDK_HOME%\tools\proguardgui\proguard-android.txt文件。


接下来在input/output菜单中分别点击【Add input…】和【Add output…】按键选择需要混淆的jar文件和混淆完毕的jar文件,为了便于混淆完毕前后比对,建议这两个文件分别取名。如46所示。


image.png

46  选择混淆的jar文件和混淆完毕的jar文件


接下来在“Library jars,wars,ears .....”区域内点击【Add…】按键,添加所有混淆的jar文件所需要辅助的jar文件包,如果用Eclipse开发,可以在Build Path看见,47显示在Proguard中添加jar文件,48显示在EclipseBuild Path显示的依赖jar包。


image.png

47  选择混淆的jar文件和混淆完毕的jar文件


image.png

48  EclipseBuild Path显示的依赖jar


      进入shrnk标签下在Also Keep下电亮所有选项,如49所示。

image.png

49  电亮所有Also Keep选项


      最后在Process下点击【Process!】按键,开始混淆。混淆完毕在“处理控制台(ProcessingConsole)”中显示“Processingcompleted successfully”。


      接下来用jdk-gui <output.jar>命令混淆完毕的jar文件对应的JAVA源码。

      试过上面操作的读者会发现Proguard仅仅对jar文件进行了简单的混淆,比如变量改为a,b,c,d…,而对程序逻辑,算法依旧清晰可见,一般在真正工作开发中希望使用一些专业化的混淆工具,比如360 APP加固器等。


星云测试

http://www.teststars.cc

奇林软件

http://www.kylinpet.com

联合通测

http://www.quicktesting.net


顾翔凡言:

图是软件项目三角形。

image.png

 软件项目三角形


      下面做如下假设。

l 假设质量(Q)与范围(S)不变,时间(T)减少的情形下,必须雇佣高水平的人员或者先进的技术,即增大产品的成本(C)。同理,质量(Q)与范围不变,时间(T)增加的情形下,可以减少成本(C)。

l 假设质量(Q)与时间(T)不变,范围(S)增加的情形下,也必须增大成本(C)。同理,质量(Q)与时间(T)不变,范围(S)减少的情形下,可以减少成本(C)。

l 假设质量(Q)与成本(C)不变,时间(T)减少的情形下,范围(S)必须减少。同理,质量(Q)与成本(C)不变,时间(T)增加的情形下,可以加大范围(S)。


于是可以得到如下公式:

Q = TC/S

  •  也就是说质量消耗单位模块的时间和金钱的乘积。从这里可以看出,完成一个功能,需要达到一定的质量,必须消耗有效的时间或者增加产品的成本投入,由此可以看出为了赶进度,盲目加班赶工是不可取的。
目录
相关文章
|
19天前
|
Java 测试技术 数据安全/隐私保护
软件测试中的自动化策略与工具应用
在软件开发的快速迭代中,自动化测试以其高效、稳定的特点成为了质量保证的重要手段。本文将深入探讨自动化测试的核心概念、常见工具的应用,以及如何设计有效的自动化测试策略,旨在为读者提供一套完整的自动化测试解决方案,帮助团队提升测试效率和软件质量。
|
11天前
|
Web App开发 IDE 测试技术
Selenium:强大的 Web 自动化测试工具
Selenium 是一款强大的 Web 自动化测试工具,包括 Selenium IDE、WebDriver 和 Grid 三大组件,支持多种编程语言和跨平台操作。它能有效提高测试效率,解决跨浏览器兼容性问题,进行性能测试和数据驱动测试,尽管存在学习曲线较陡、不稳定等缺点,但其优势明显,是自动化测试领域的首选工具。
91 17
Selenium:强大的 Web 自动化测试工具
|
22天前
|
机器学习/深度学习 人工智能 算法
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
BALROG 是一款用于评估大型语言模型(LLMs)和视觉语言模型(VLMs)在复杂动态环境中推理能力的基准测试工具。它通过一系列挑战性的游戏环境,如 NetHack,测试模型的规划、空间推理和探索能力。BALROG 提供了一个开放且细粒度的评估框架,推动了自主代理研究的进展。
31 3
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
|
29天前
|
监控 测试技术 开发工具
移动端性能测试工具
移动端性能测试工具
43 2
|
1月前
|
安全 前端开发 测试技术
如何选择合适的自动化安全测试工具
选择合适的自动化安全测试工具需考虑多个因素,包括项目需求、测试目标、系统类型和技术栈,工具的功能特性、市场评价、成本和许可,以及集成性、误报率、社区支持、易用性和安全性。综合评估这些因素,可确保所选工具满足项目需求和团队能力。
|
1月前
|
安全 网络协议 关系型数据库
最好用的17个渗透测试工具
渗透测试是安全人员为防止恶意黑客利用系统漏洞而进行的操作。本文介绍了17款业内常用的渗透测试工具,涵盖网络发现、无线评估、Web应用测试、SQL注入等多个领域,包括Nmap、Aircrack-ng、Burp Suite、OWASP ZAP等,既有免费开源工具,也有付费专业软件,适用于不同需求的安全专家。
132 2
|
1月前
|
监控 网络协议 Java
一些适合性能测试脚本编写和维护的工具
一些适合性能测试脚本编写和维护的工具
|
1月前
|
Web App开发 定位技术 iOS开发
Playwright 是一个强大的工具,用于在各种浏览器上测试应用,并模拟真实设备如手机和平板。通过配置 `playwright.devices`,可以轻松模拟不同设备的用户代理、屏幕尺寸、视口等特性。此外,Playwright 还支持模拟地理位置、区域设置、时区、权限(如通知)和配色方案,使测试更加全面和真实。例如,可以在配置文件中设置全局的区域设置和时区,然后在特定测试中进行覆盖。同时,还可以动态更改地理位置和媒体类型,以适应不同的测试需求。
Playwright 是一个强大的工具,用于在各种浏览器上测试应用,并模拟真实设备如手机和平板。通过配置 `playwright.devices`,可以轻松模拟不同设备的用户代理、屏幕尺寸、视口等特性。此外,Playwright 还支持模拟地理位置、区域设置、时区、权限(如通知)和配色方案,使测试更加全面和真实。例如,可以在配置文件中设置全局的区域设置和时区,然后在特定测试中进行覆盖。同时,还可以动态更改地理位置和媒体类型,以适应不同的测试需求。
64 1
|
2月前
|
Java 流计算
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
45 1
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
|
2月前
|
jenkins 测试技术 持续交付
提升软件测试效率的实用技巧与工具
【10月更文挑战第12天】 本文将深入探讨如何通过优化测试流程、引入自动化工具和持续集成等策略,来显著提高软件测试的效率。我们将分享一些实用的技巧和工具,帮助测试人员更高效地发现和定位问题,确保软件质量。
69 2
下一篇
DataWorks