ios技术资料总结

iOS Reveal 非越狱真机断点调试

2018-08-12  本文已影响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

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;

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了!

上一篇 下一篇

猜你喜欢

热点阅读