文档章节

android 反编译 smali 调试

yoke白板
 yoke白板
发布于 2016/08/01 17:51
字数 393
阅读 75
收藏 1

 

0x00    前言

之前对于app反编译的smali汇编语言都是静态分析为主,加上一点ida6.6的动态调试,但是ida的调试smali真的像鸡肋一样,各种不爽,遇到混淆过的java代码就欲哭无泪了。后来知道IDEA用一款插件也可以实现smali的动态调试,但是只有14.1之后的版本才支持。idea是一款商业软件,懒得去找各种破解版,就想着用androidstudio来代替idea来达到动态调试的目的。

 

0x01    工具

①Android Studio 1.5Preview,不清除低版本的是否支持smali的调试

②apktool,尽量使用最新版的。

③ideasmali插件。下载地址

 

0x02     具体步骤

         安装ideasmali插件,File->Settings->Plugins,安装之前下载的ideasmali插件。

              

    反编译apk 

    

    以调试状态启动app,并转发8700端口  [app_pid]

    

    

    

            

            记住这时候需要将DDMS关掉,不然会出现错误

            

    使用AS导入之前反编译的目录,这里选择debugsmali文件夹就可以了。

           

    然后选择Create project from existing sources,之后一直选择next。

           

    对之前反编译的debugsmali/src文件夹右键-->Make Directory As --->Source Root

        

         配置远程调试的选项,选择Run-->Edit Configurations:

            

          增加一个Remote调试的调试选项,端口选择:8700

           

       之后选择File-->Project Structure 配置JDK

           

            

        下好断点之后Run-->Debug'smali',这里的smali是我们之前配置好的调试选项。  

             

            运行起来之后就可以单步执行,查看寄存器的值,慢慢调试了。

             

 

本文转载自:http://www.cnblogs.com/lanrenxinxin/p/4891424.html

共有 人打赏支持
yoke白板
粉丝 1
博文 20
码字总数 2912
作品 0
杭州
CEO
私信 提问
基于Android studio动态调试smali全过程

1 工具和环境 Android studio 用于集成idea插件和导入smali源码 idea插件 插件下载 或者在studio中搜索Smalidea进行插件下载(要翻墙) 在Android studio中通过idea插件来调试smali和在idea中...

gavinme
07/23
0
0
Android 逆向分析(三)之动态调试Smali

动态调试smali 实战 反编译后修改AndroidMainfest.xml 在Application节点下添加 android:debuggable="true" 回编译用原来签名 打包apk 重新装到手机上 工具,现在我们开发都用的是Android S...

蔡小鹏
2017/03/24
0
0
android 反编译工具

1、smali-1.2.6.jar 用途:.smali文件 转成 classes.dex文件 说明:.smali文件,类似于.class文件,可以用普通文本编辑器查看和修改。 用法举例:命令行:java -jar smali.jar classout/ -o ...

SamZel
2012/05/29
0
0
eclipse和android源码编译应用效果有差异

一般来说,eclipse只是IDE开发工具,它虽然能编译apk,但是大多数开发情况下,都会要求必须在源码里编译通过,达到工程化,而不是单单的demo。 问题: 这次悲催而又诡异的遇到了这么个问题:...

blackylin
2013/06/27
0
2
Android的反编译和代码混淆

系列文章: Android的反编译和代码混淆 Android的打包签名 Android的多渠道打包 前言 包括以下内容 要反编译apk需要下面3个工具 反编译资源文件 反编译类文件 代码混淆 要反编译apk需要下面3...

跳动的松鼠
2017/11/21
0
0

没有更多内容

加载失败,请刷新页面

加载更多

MySQL Replication 梳理详解

MySQL Replication 1 MySQL5.5以前的复制 异步、SQL线程串行化回放 MySQL内建的复制功能是构建大型,高性能应用程序的基础。主服务器将更新写入二进制日志文件,从服务器重新执行一遍来实现的...

PeakFang-BOK
今天
1
0
.NET Core & ConsoleApp & appsettings.json

准备 Visual Studio 2017 .NET Core 2.1 新建控制台应用(.NET Core) 默认的 Program.cs // Program.csusing System;namespace ConsoleApp1{ class Program { static voi......

taadis
今天
2
0
结合lucene谈谈日期的压缩问题

说起日期值的压缩,一般容易想到的办法是将日期转化成long类型,然后再通过变长整形进行压缩,我算了一下按照毫秒来算最多占用5个字节(可以通过“谈谈变长整型”中的表查看),确实节省了部...

FAT_mt
今天
1
0
导出私有函数与私有变量

在Go语言中, package中包含函数与变量通过identifier的首字母是否大写来决定它是否可以被其它package所访问。当一个函数或变量名称为小写字母时,默认是无法被其他package引用的. 有没有办法...

xtof
今天
2
0
new Date() 在Safari下的 Invalid Date问题

问题复现 var timeStr = '2018-11-11 00:00:00';var time = new Date(timeStr);// error: Invalid Date... 在safari浏览器下,time为Invalid Date, 导致后面代码执行错误; 其他浏览器诸...

会写代码的husky
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部