美文网首页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 非越狱真机断点调试

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