smali是目前Dalvik指令集最适合阅读和解析的汇编语法,是做Android软件逆向分析必须学习的内容。比较可惜的是,到现在也没有特别好的smali阅读工具。下面给出的是平时习惯的Vim+Ctags组合下阅读smali的方法。先看最终效果:
可以看到,vim支持smali的语法高亮,ctags支持解析smali中的域和方法。实现这个的方法如下:
1. 下载这个文件:
2. 解压缩,将其中的smali.vim拷贝至~/.vim/syntax/目录。在~/.vimrc中增加:
filetype on
filetype plugin on
filetype indent on
|
在~/.vim/filetype.vim中增加:
au BufRead,BufNewfile *.smali set filetype=smali
|
这样,vim就支持smali语法高亮了。
3. 假设已经装好了ctags工具和vim-taglist插件,接下来,将上面压缩包中的ctags.conf拷贝至~/.ctags,将其中的taglist.vim拷贝至~/.vim/plugin/目录并覆盖原来的taglist.vim,这样,就可以在vim中通过taglist调用ctags解析smali文件中的域和方法了。
需要补充两点说明;
1. smali.vim的作者是lohan,博客地址是:http://androidcracking.blogspot.com/ ,他还提供了UltraEdit和Notepad++的smali语法高亮文件;
2. 通过apktool调用smali工具反汇编出来的结果中,文件名大量包含‘$’符号,目前taglist对包含这类符号的文件名处理有一个bug,因此我修改了taglist的代码,使其正确处理。