APK文件分析工具:AppMon

   2016-11-22 0
核心提示:对手机恶意软件研究人员来说,有很多APP行为分析工具可以选择,在这里,我要向大家推荐的是AppMon,它可以通过二进制指令获取app程序运行记录,并显示调用函数和相关参数。AppMon工作原理AppMon使用了多平台动态框架环境Frida,Frida是一款基于python + javas

APK文件分析工具:AppMon

对手机恶意软件研究人员来说,有很多APP行为分析工具可以选择,在这里,我要向大家推荐的是AppMon,它可以通过二进制指令获取app程序运行记录,并显示调用函数和相关参数。

AppMon工作原理

AppMon使用了多平台动态框架环境Frida,Frida是一款基于python + javascript 的hook框架,适应android\ios\linux\win\osx等平台的脚本交互环境。AppMon还包括了一系列app事件监控和行为修改脚本,并能通过web接口显示和操作。

安装

AppMon的运行环境需要Frida和其它模块:

sudo -H pip install argparse frida flask termcolor

Linux环境下可以克隆github安装:

https://github.com/dpnishant/appmon/

如果是Windows环境,下载解压之后,需要对appmon.py中变量merge_script_path的绝对路径进行修改,可以是临时文件夹或其它所需文件路径,如:

merge_script_path = ‘C:/Users/<nombre_usuario>/AppData/Local/Temp/merged.js

考虑到Frida的稳定性,推荐使用Android 4.4.x版本模拟器,另外,建议用adb命令安装apk程序。

分析

让我们来分析一个恶意程序样本 Android/Torec.A ,该程序可以实现窃取短信和通话记录等关键信息,并能利用 Tor网络的.onion代理服务器隐藏指令控制服务器,远程执行代码。程序Manifest文件显示包名为com.baseapp,现在开始启动AppMon控制端:

APK文件分析工具:AppMon

Windows下的启动界面如下:

APK文件分析工具:AppMon

AppMon创建了一个访问5000端口的简单服务器,实现web界面的分析显示:

APK文件分析工具:AppMon

打开浏览器,选择需要分析的APK文件,点击“Next”:

APK文件分析工具:AppMon

之后,将会显示apk程序执行阶段短暂的事件日志记录:

APK文件分析工具:AppMon

我们再以 Android/Monitor.Rasatremon.A 为分析样本执行程序,通过web界面日志记录,可以看到具体的HTTP网络连接活动:

APK文件分析工具:AppMon

APK文件分析工具:AppMon

除此之外,AppMon还有其它功能,如密码恢复等。总之,对apk分析来说,它是一款好用的工具。

具体参见: https://dpnishant.github.io/appmon/

*参考来源: welivesecurity ,FB小编clouds编译,转载请注明来自FreeBuf(FreeBuf.COM)

 
标签: Linux Windows
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • 使用Smalidea对无源码APK调试简介
    阅读:8最近正好也用了Smalidea,就ZZ的原贴做一些补充。可调试APP如果Android的系统属性ro.debuggable等于1(用getprop ro.debuggable验证),则所有APP都可调试。如果ro.debuggable等于0,某APP的AndroidManifest.xml中有android:debuggable=”true”,该APP
    01-06 JavaLinux
  • 浅入浅出 Android 安全:第二章 Android Linux 内核层安全
    浅入浅出 Android 安全:第二章 Android Linux
    第二章 Android Linux 内核层安全 来源: Yury Zhauniarovich | Publications译者:飞龙协议: CC BY-NC-SA 4.0 作为最广为人知的开源项目之一,Linux 已经被证明是一个安全,可信和稳定的软件,全世界数千人对它进行研究,攻击和打补丁。 不出所料,Linux 内
  • Android的init过程详解(一)
    Android的init过程详解(一)
    Android的init过程(二);初始化语言(init.rc)解析 本文使用的软件版本 Android: 4.2.2Linux内核: 3.1.10 本文及后续几篇文章将对Android的初始化(init)过程进行详细地、剥丝抽茧式地分析,并且在其中穿插了大量的知识,希望对读者了解Android的启动过
  • ShowJoy开发记录
    命令输入位置:AndroidStudio-Terminalgradle –stop标题中的命令错误:应该为gradle --stop,注意是两个-符号!!!作用:可以快速停止 gradle 启动的进程。gradle shopandroid:dependenciesdependencies.txt解释shopandroid:想要查找依赖关系的模块名(Mod
    11-03 GradleLinux
  • Linux与Android的关系
    Linux与Android的关系
    大家都知道Android是基于Linux内核的操作系统,也曾经和Linux基金会因为内核问题产生过分歧,本文将开始对Android的内核进行剖 析,主要介绍Android和Linux之间的关系,后续还会讲到Android系统在Linux系统之上扩展的部分功能和驱动。虽然Android基于Linux内
  • Linux下小米平板2从win10刷回miui
    Introduction小米平板2感觉win10的体验一般般,可能用来救个急还是不错的。但是论坛里从win10刷回miui都是在win下的操作,我的win装在了虚拟机里,即使usb挂到了虚拟机里,执行论坛里的操作也有问题。简单看了下别人写的一键脚本,发现很简单。就自己在linux
  • 基于linux与windows平台下 如何下载android sdk
    本文主要是介绍在linux和windows平台下,如何下载android sdk的源代码,注意是sdk的源代码,而不是android的所有源代码,同时介绍如何把sdk源代码加入到eclipse里,使android 平台手机开发者可以直接查看源代码,通过阅读SDK源码,能更好的理解和运用Android的API
  • 基于Android SDK-在64位Linux中使用需要注意的
    本篇文章是对Android SDK-在64位Linux中使用需要注意的问题进行了详细的分析介绍,需要的朋友参考下
  • 如何在Linux上开发跨平台的移动应用程序?
    如何在Linux上开发跨平台的移动应用程序?
    过去这几年见证了移动市场的迅猛发展,推动这个市场发展的主要是一大批应用程序。作为消费者,我们都讨厌看到任何一种平台造成的某种市场垄断局面。毕竟,竞争越激烈,创新越多。作为开发人员,我们对跨平台开发怀有复杂的心情。跨平台开发存在几个缺点,比如糟糕的平台集成和欠灵活的设计等等。可是另一方面,我们又能够接触拥有更多消费者的更广阔市场,能够为我们开发的应用程序在众多平台上提供统一的外观和感觉。
    06-24
点击排行