美文网首页ios技术资料总结
iOS Reveal 非越狱真机断点调试

iOS Reveal 非越狱真机断点调试

作者: 一只代码狗 | 来源:发表于2018-08-12 23:29 被阅读262次

Reveal 是我们调试UI的利器,他避免了每次调试UI时一旦修改UI就需要重新cmd+R重新运行的麻烦操作,我们只需要接入Reveal,然后在Reveal操作界面修改UI属性,可以直接反应在运行的App中!如下图的Reveal主界面,最左边反应树形UI视图层级,中间是一个3D的UI显示层级,右边类似我们在使用xib时选中某个元素可以修改元素的各种属性的操作,修改完成后无需运行直接反应在我们的模拟器或者真机上面!方便极了

image.png

模拟器的调试

1:添加断点按钮,添加一个Symbolic BreakPoint

image.png

2:输入Symbol:UIApplicationMain

image.png

3:add Action

image.png
  • version 1.6.3 (5790)
    • 模拟器

expr (Class)NSClassFromString(@"IBARevealLoader") == nil ? (void )dlopen("/Applications/Reveal.app/Contents/SharedSupport/iOS-Libraries/libReveal.dylib", 0x2) : ((void)0);

  • 真机

expr (Class)NSClassFromString(@"IBARevealLoader") == nil ? (void *)dlopen((char *)[(NSString *)[(NSBundle )[NSBundle mainBundle] pathForResource:@"libReveal" ofType:@"dylib"] cStringUsingEncoding:0x4], 0x2) : ((void)0;

  • version 4 (8769)
    • 模拟器

expr (Class)NSClassFromString(@"IBARevealLoader") == nil ? (void )dlopen("/Applications/Reveal.app/Contents/SharedSupport/iOS-Libraries/RevealServer.framework/RevealServer", 0x2) : ((void)0);

  • 真机

(Class)NSClassFromString(@"IBARevealLoader") == nil ? (void)dlopen((char)[(NSString)[(NSString)[(NSBundle)[NSBundle mainBundle] pathForResource:@"RevealServer" ofType:@"framework"] stringByAppendingPathComponent:@"RevealServer"] cStringUsingEncoding:0x4], 0x2) : ((void)0);

4:选中Automatically continue after evaluating actions. image.png

5:至此如果是模拟器的话,直接cmd+R,即可!

image.png

真机的调试

真机的调试比较麻烦,文档里面没有直接说明,所以坑很多!自己参考了唐巧的iOS开发进阶里面说的,但是没有用,经过资料查询,终于解决了这个问题!

要用Reveal连接真机调试,我们需要将Reveal的动态链接库直接打包到程序里面去,原因是:iOS系统的沙盒机制,在未越狱的情况下,我们不可能访问到Reveal的动态链接库!只有打包到工程去!

打开我们的Reveal,在菜单栏Help=>Show Reveal Library in Finder选项,选择iOS Library会打开Finder,将Finder里面的libReveal.dylib(v1.6.3)或者RevealServer.framework(v4)拖动到工程中,选择Create Folder Reference,取消Add to Target

image.png

在Target=>Build Parse=>Copy Bundle Resource 将刚刚拖进工程的文件添加进去

image.png

按照唐巧的书写的此时cmd+R就应该可以连接成功了

照他说的没用!

怎么办!怎么办!怎么办!

多方查资料得知:应该是libReveal.dylib(v1.6.3)或者RevealServer.framework(v4)没有签名!想想也是,在我们的iOS系统中,为了安全起见,我们是不能运行没有签名过的代码的!

iOS这样做的好处是,当我们得到了一个App的运行包时,我们不能简单的修改二进制文件然后在重新装机!

但还是有方法可以实现的,原理就是注入动态链接库+重签名!详情可参考iOS冰与火之歌番外篇 - 在非越狱手机上进行App Hook

所以我们需要运行的时候给libReveal.dylib(v1.6.3)或者RevealServer.framework(v4)签名!

选择target=>build parse

image.png

点击加号,选择New Run Script Phase

image.png

添加以下脚本对libReveal.dylib(v1.6.3)或者RevealServer.framework(v4)签名!

// v4

set -e

if [ -n "${CODE_SIGN_IDENTITY}" ]; then

codesign -fs "{CODE_SIGN_IDENTITY}" "{BUILT_PRODUCTS_DIR}/${FULL_PRODUCT_NAME}/RevealServer.framework/RevealServer"

fi

v1.6.3

set -e

if [ -n "${CODE_SIGN_IDENTITY}" ]; then

codesign -fs "{CODE_SIGN_IDENTITY}" "{BUILT_PRODUCTS_DIR}/${FULL_PRODUCT_NAME}/libReveal.dylib"

fi

image.png

至此cmd+R运行即可在连接列表中发现我们刚刚运行的App了

image.png

选中后即可看到如下界面

image.png

至此Reveal集成完毕!接下来你就可以快乐的调试UI了!

相关文章

  • iOS Reveal 非越狱真机断点调试

    Reveal 是我们调试UI的利器,他避免了每次调试UI时一旦修改UI就需要重新cmd+R重新运行的麻烦操作,我们...

  • iOS逆向与安全9.1:越狱调试

    Reveal Reveal是一款UI调试神器,对iOS开发非常有帮助。尤其是越狱调试,能让越狱开发如虎添翼。 安装...

  • iOS越狱开发入门帮助文档

    工具列表:Reveal 2真机查看其它应用 旧版本Reveal安装要求一台能够越狱的iPhone,最好是iOS7或...

  • ios工具篇

    iOS真机UI调试利器——RevealReveal及简单破解方法 把Reveal.framework加入工程,在弹...

  • Reveal越狱真机调试其他APP

    前言 有的时候在做APP布局的时候一时半会想不到很好的布局方式,恰好这个时候找到相似的APP,并且又有一部越狱的手...

  • Reveal 动态查看 APP UI 结构

    Reveal 一款强大的iOS UI调试工具,可以用于透视程序整体结构,如果需要看其他App的程序结构只能在越狱机...

  • reveal 教程

    为什么要用reveal,以及扯淡 reveal下载和安装,以及安装遇到的问题 模拟器和真机如何使用reveal调试...

  • iOS越狱-如何配置Reveal查看调试App UI界面

    Reveal是一款调试iOS程序UI界面的神器 越狱手机上调试环境配置 1.iPhone手机上通过Cydia安装R...

  • Reveal调试UI利器

    Reveal Reveal是分析、调试iOS应用UI的利器。 Reveal能够在运行时调试和修改iOS应用程序。它...

  • iOS界面调试工具 Reveal

    iOS界面调试工具 Reveal --该文作者唐巧 Reveal的使用 用Reveal连接模拟器调试 Reveal...

网友评论

    本文标题:iOS Reveal 非越狱真机断点调试

    本文链接:https://www.haomeiwen.com/subject/mqgebftx.html