IT门户, 中国互联网人工智能物联网行业资讯平台--公众IT

当前位置:公众IT > 技术文章 >

新闻来源:互联网资料整理       发布时间:2023/4/5 17:58:47       共计:4626 浏览

很高兴该问题,下面我从语言基础知识、安卓逆向基础知识、逆向进阶知识三个方面介绍安卓逆向的学习路线。

逆向学习是一个动手动脑的过程、在学习的过程中要多动脑多动手灵活运用学习的知识。

语言基础知识

Java语言基础

Android程序是用java语言开发的,所以学好Java基础是非常必要的。

Android基础


既然是安卓逆向分析,那么一定学要学习好安卓知识。熟练使用安卓的开发语言如Java、C/C++、kotlin,dart等,同时还要掌握安卓虚拟机原理运行机制、app打包过程、系统启动流程、App启动详细过程。只有懂得正向过程,才能在逆向分析的时候进行还原分析。

C/C++

在很多公司不再是纯粹的Java层开发,更多的会与C++结合,把一些重要的方法和行为以及一些私密性质的东西放在C++中。

ARM汇编语言

安卓CPU主要是ARM。

能写简单的脚本和爬虫

安卓逆向基础知识

1、工具的使用如apktool,IDA,dex2jar,JEB,Androidkiller,Androguard等。

1)、apktool主要用于逆向apk文件。

2)、IDA非常好用的交互式反汇编的软件。

3)、dex2jar用于将dex文件转为jar文件。

4)、JEB安卓动态调试工具。

5)、Androidkiller 强大的apk反编译工具,支持修改查看smail文件及二次编译打包。

2、Smali汇编语言学习

smali语言是安卓虚拟机的执行语言,apk编译后的可执行dex文件里面就是smail语言。

3、熟练使用抓包工具进行抓包如burpsuit、Fiddler和Charles。

4、了解ARM,熟悉IPC原理,能够熟练搭建IPC框架。

5、Android 基础算法和安全协议--如密码学、数字签名、服务端与客户端通信协议。

安卓逆向进阶知识

hook技术-xposed框架fridaADBI框架

Android NDK--快速开发C、 C++的动态库,并自动将so和应用一起打包成 APK即可通过 NDK在 Android中 使用 JNI与本地代码(如C、C++)交互。

JNI--是一种在Java虚拟机控制下执行代码的标准机制。代码被编写成汇编程序或者C/C++程序,并组装为动态库。也就允许了非静态绑定用法。这提供了一个在Java平台上调用C/C++的一种途径。

Android 加固防护--”知己知彼,百战百胜“,只有了解加壳的过程及原理才能更好进行脱壳,所以要掌握市面上的app加壳技术原理如梆梆加固原理、爱加密加固原理、百度加固DD大法、阿里加固原理、360加固原理等。

Android 脱壳技术--掌握安卓脱壳思路、勤加练习。

学习逆向需要有一颗坚持和钻研的心,希望对你有帮助!

看这个都没用的 出版的书籍都把敏感技术和邪恶技术删除了

我有非常顶级的破解技术 要不要试试?

版权说明:
本网站凡注明“公众IT 原创”的皆为本站原创文章,如需转载请注明出处!
本网转载皆注明出处,遵循行业规范,如发现作品内容版权或其它问题的,请与我们联系处理!
您可以扫描右侧微信二维码联系我们。
·上一条: | ·下一条:
同类资讯
网站首页 关于我们 联系我们 合作联系 会员说明 新闻投稿 隐私协议 网站地图