iOS UI调试之IPAPatch与Reveal的搭配实现三方App分身、UI层级浏览

前言

开发人员不会因为做不出一个功能而头疼,大部分开发人员头痛的是,如何采用一些大厂的实现方案,达到便于维护、性能优异的目的。尤其对于UI开发来说,能找到其他主流App的实现方案,确实能帮助开发者减少页面设计、调试、性能上的负担。
  接下来我们就利用IPAPatch和Reveal来让手机不越狱查看一些App的UI层级关系(例如:QQ、微信等),当然调试只支持真机调试,这一点需要注意。

流程

IPAPatch通过将ipa文件替换为Xcode编译项目的.app文件的方式,让ipa文件可以以Xcode真机调试的方式,安装到调试手机上。

一、IPAPatch项目

首先下载IPAPatch的项目,git地址:https://github.com/Naituw/IPAPatch,下载完成后,用Xcode打开项目。

iOS UI调试之IPAPatch与Reveal的搭配实现三方App分身、UI层级浏览_第1张图片
项目面板

我们找到项目设置,可以发现这里是跟我们平常开发的项目是一样的,选择好我们的开发证书,修改好BundleID即可运行。

二、替换ipa文件

之前说过,IPAPatch通过替换.app的方式,让ipa在我们的手机上运行。我们就需要找到我们想了解的App的ipad包。这里需要说明的是,正常App Store上下载的ipa文件,是加密的,我们没法知道里面的任何代码,同样IPAPatch也是通过解密的方式,将ipa的代码进行修改以供使用的。加密的ipa文件外面有一层壳,我们要拿到的是剥了壳的ipa文件。
  想下载这些解密了的ipa,直接去越狱商店下载就好。这里以我所用的手机助手为例。


iOS UI调试之IPAPatch与Reveal的搭配实现三方App分身、UI层级浏览_第2张图片
同步助手

  找到越狱商店,下载微信:


iOS UI调试之IPAPatch与Reveal的搭配实现三方App分身、UI层级浏览_第3张图片
越狱商店

  下载好后,可以在“下载管理”中找到我们下载的ipa。
iOS UI调试之IPAPatch与Reveal的搭配实现三方App分身、UI层级浏览_第4张图片
找到下载的ipa文件

  修改ipa文件名为app.ipa,将这个文件放在我们下载的git工程的如下路径下:
iOS UI调试之IPAPatch与Reveal的搭配实现三方App分身、UI层级浏览_第5张图片
ipa存放路径

接下来直接运行项目,即可将ipa文件安装到我们的手机上,当然仅限真机。安装后,不会覆盖原来的App,因为Bundle ID是不一样的。

iOS UI调试之IPAPatch与Reveal的搭配实现三方App分身、UI层级浏览_第6张图片
共存

三、代码注入

打开新安装的微信,会弹出一个AlertView提示,这是我们注入的代码。


iOS UI调试之IPAPatch与Reveal的搭配实现三方App分身、UI层级浏览_第7张图片
代码注入

四、Reveal调试

既然新的ipa以Xcode真机调试的方式运行在我们手机上,则我们可以通过Reveal来调试它的UI。
  Reveal下载:http://xclient.info/s/reveal.html
  安装好后,找到RevealServer.framework,集成到我们的项目中。Reveal通过这个framework来对我们调试的App进行UI的解析。
  在Reveal的Help中,我们可以找到RevealServer.framework。

iOS UI调试之IPAPatch与Reveal的搭配实现三方App分身、UI层级浏览_第8张图片
Reveal

  将RevealServer.framework放到我们项目的指定目录下,IPAPatch会将这个framework注入到微信App中。

iOS UI调试之IPAPatch与Reveal的搭配实现三方App分身、UI层级浏览_第9张图片
framework路径

重新运行项目,再打开Reveal。我们可以看到正在运行的可Reveal调试的App:

iOS UI调试之IPAPatch与Reveal的搭配实现三方App分身、UI层级浏览_第10张图片
Reveal

点击其中任意一个,即可查看App的UI布局了:

iOS UI调试之IPAPatch与Reveal的搭配实现三方App分身、UI层级浏览_第11张图片
Reveal调试

同样Reveal也可以用来调试我们自己开发的App,但要在上线的时候保证RevealServer.framework从项目中移除,因为这个框架中用到了苹果的私有API。

总结

以上功能不仅让我们可以分身应用,还可以看到任何三方App的UI结构、层级,在开发中可以参考一些成熟厂商所开发的App的解决方案,不仅让我们开发者少走弯路,也为我们开发者提供了更多的新思路,让我们技术成长更快。
  参考文章:http://weibo.com/ttarticle/p/show?id=2309404086977153611942 整理加强而成,适合任何开发新手

你可能感兴趣的:(iOS UI调试之IPAPatch与Reveal的搭配实现三方App分身、UI层级浏览)