对于一个iOS开发者,可能你会遇到瓶颈,不知道要从哪里开始学习以及研究的方向不知道在哪,其实在网上可以看到很多方向.比如视频编解码、iOS逆向、RN、框架等方向。我也是想多方面发展。一直在关注各个并研究学习,之前在公司内部写了一些博客,但是公司网络限制不能再外网访问,所以目前打算重新整理下知识。另一方面就是最近看到网上一些招聘上都需要有博客或者可以通过这个加分增加面试的机会。
我也建议开发者可以写一下博客,一方面可以记录、整理自己学习的知识,一方面还可以锻炼自己书写能力,另一方面也能让别人发现你的才能。
这篇博客主要介绍下iOS逆向的一些知识点、一些我常用的基础工具。后续会继续写这方面的知识,将自己了解的逆向知识整理成博客,欢迎大家指正、指导。
非越狱逆向基础
1.首先逆向开发是基于砸过壳的APP(在App Store直接下载的APP是加壳的)通过静态分析/动态分析,分析出别人App的逻辑、布局等的实现原理,从而学习他人开发的技巧。
2.这里的非越狱是手机不需要越狱就可以逆向开发。
3.逆向原理是通过重签名的方式将砸壳的app重新跑到手机上开发、调试。
非越狱逆向开发工具
1.首推monkeyDev,这个只需要一个砸壳后的app,放到指定位置,通过Xcode就能重签名到你测试手机中调试。很强大的一个工具。
2.PP助手,这个上面很多砸壳后的app可以直接下载,在没学会砸壳技术之前可以到这个软件上直接下载。
3.MachOView,查看app的machO文件。
4.IDA,静态分析工具,查看二进制文件。
5.Sublime Text文本编辑工具,导出APP头文件后,可以用这个编辑、查找等,功能强大。
这些工具在后续用到我会一一介绍。工具使用是为了开发更加方便、提高效率。
非越狱逆向要点
1.ARM64(iPhone 5s及5s以上的架构)汇编知识.汇编比较重要,在分析别人逻辑的时候,大部分都是在分析汇编这个知识要扎实,但是不会也是可以做逆向开发的why?大家都是有开发经验人员,可以用到了哪个然后在去查,慢慢学习。
2.iOS开发基础知识。
3.不怕困难,充分利用网上资源解决困难。
4.不怕困难...
5.不怕困难...