博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
VKDevTool App黑盒调试工具
阅读量:6994 次
发布时间:2019-06-27

本文共 2792 字,大约阅读时间需要 9 分钟。

迁移老文章到掘金

前言

这个工具在早期的VKDebugConsole的基础上完全推翻重做了,核心思路都不变,只是重新整理了工具的使用方式,工具的界面呈现,工具的模块划分,模块化可扩展支持

VKDevTooL

允许在

  • 在脱离Xcode Debug的情况下
  • 黑盒真机情况下

进行App的调试工作,包括:

  • 调试内存对象
  • 打印内存数据
  • 修改UI
  • 查看NSLog
  • 查看所有网络请求记录
  • 查看App界面层级

方便在黑盒测试+内部体验的环境下,发现Bug后,直接在Bug现场调试内存,分析问题

使用介绍

工程配置

  • VKDevTool文件夹拖入工程文件
  • VKDevToolLogHeader.h写入pch,以便开启NSLog的动态拦截记录,不导入ConsoleLog模块无法捕获NSLog
  • 可以修改VKDevToolDefine.h中的#ifdef DEBUG来进行自定义的编译控制,如果不修改,默认Debug模式下VKDevTool工具才有效

编写代码

[VKDevTool enableDebugMode];复制代码

一行代码即可开启DevTool的功能,该功能内部有编译控制,Release版本会自动失效,无需使用者在这行代码外围在套一层#ifdef DEBUG

如何使用

进行完工程配置与写入代码之后可以通过如下方式,在App内打开工程模式菜单

  • 模拟器下,使用键盘command+x快捷键唤起菜单
  • 真机运行下,使用摇一摇唤起菜单

主菜单模块包含4个模块

  • DebugScript
  • ConsoleLog
  • NetworkLog
  • ViewHierarchy3D

VKDevTool采取模块化设计,每个模块Module都可以独立分拆分离,同时支持用户定义扩展自己的模块,图中的额外2个模块为自定义模块

黑盒调试功能DebugScript

  • 在主菜单中选择DebugScript
  • 按提示点选任意一个界面元素
  • 进入代码控制台
  • 上面是代码输入框
  • 下面是输出框

以上是一个预览界面,上方输入的代码都是基于JSPatch的,所有JSPatch的语法规则这里都一模一样可以使用,戳这里看JSPatch如何使用

  • 真机摇一摇 or 模拟器Command+X 可以唤起DebugScript模块子菜单
  • 模拟器下如果输入过代码Command+X可能不好使,通过模拟器菜单Shake Gesture功能模拟摇一摇,依旧可以唤起

子菜单包含以下几个功能

  • GetTarget:自动往输入框中输入getTarget的脚本代码,执行以后print Target信息,便于后续直接调试target的任意内存数据和执行方法

  • Get TargetVC:自动往输入框中输入getTargetVC的脚本代码,执行以后print Target所在的当前vc的信息,便于后续直接调试targetVC的任意内存数据和执行方法

  • ChangeTarget:自动往输入框中输入切换所选target的代码,执行后,重新返回选择target界面

  • ClearInput:清空输入区域

  • ClearOutput:清空输出区域

  • Exit:退出DebugScript

除此之外,DebugScript为JS代码添加了一个功能print()函数,可以print任意OC对象,如果对象是View,还会有额外的frame等信息输出

我们通过一个GIF动画,大体看一下调试JS代码如何使用,此处的Gif是旧的Gif,新版本的颜色样式都已经调整,加了子菜单快捷方式,但是用法完全不变

日志拦截功能ConsoleLog

在PCH中加入了VKDevToolLogHeader.h后,本模块会拦截所有NSLog打印日志,以及NSError生成记录,在这个界面进行列表展示

  • NSLog记录采用宏覆盖的方式,拦截接管了所有NSLog请求,以白色展现在界面内。
  • NSError记录采用Runtime Swizzle的方式,拦截了NSError的init,以红色展现在界面内

真机摇一摇 or 模拟器Command+X 可以唤起ConsoleLog模块子菜单

  • NSError Hook:开启和关闭NSError拦截
  • Copy to Pasteboard:把所有日志信息拷贝到剪切板
  • Search Keyword:在众多日志中搜索关键字,关键字以蓝色展示
  • Exit:退出

网络拦截功能NetworkLog

VKDevTool会采用NSURLProtocol的方案,拦截hook所有的http请求,一一记录起来,以列表的形式,展现在NetworkLog模块内

每个cell,都可以点击查看每一条网络请求的真实返回数据,并且支持复制到剪切板

真机摇一摇 or 模拟器Command+X 可以唤起NetworkLog模块子菜单

  • Network Hook:可以选择开启和关闭http拦截
  • Change Filter:可以通过过滤器,过滤含有固定字符串的网络请求,方便查找搜索
  • Exit:退出

如果NetworkHook无效,查看是否是因为AFN sessionManager需要注册NSURLProtocol导致的

NSURLSessionConfiguration *configuration= [NSURLSessionConfiguration defaultSessionConfiguration]; NSArray *protocolArray = @[[VKURLProtocol class]]; configuration.protocolClasses = protocolArray 复制代码

页面层级ViewHierarchy3D

VKDevTool采用YY大神开源的,实现了这个页面层级模块

  • 真机摇一摇 or 模拟器Command+X 可以唤起ViewHierarchy3D模块子菜单
  • 模拟器下Command+X可能不好使,通过模拟器菜单Shake Gesture功能模拟摇一摇,依旧可以唤起

其他扩展代码

[VKDevTool changeNetworktModuleFilter:@“xxxxx”];复制代码

这个接口控制网络请求HookLog的过滤器,只拦截含有xxxx字符串的http网络请求,同时在DevTool内还可以通过菜单,修改网络拦截过滤器

如果全都拦截,可以省略

[VKDevTool registKeyName:@"custom module name" withExtensionFunction:^{    //todo your code}];复制代码

VKDevTool采取模块化设计,每个模块Module都可以独立分拆分离,同时支持用户定义扩展自己的模块

这个接口用于给VKDevTool扩展主菜单模块,可以省略不写,只使用自带的4个模块。

转载地址:http://suzvl.baihongyu.com/

你可能感兴趣的文章
Android 九宫格
查看>>
BZOJ2440:[中山市选2011]完全平方数(莫比乌斯函数)
查看>>
有关xerosploit运行报错问题的有效解决方案
查看>>
ABP官方文档翻译 1.4 启动配置
查看>>
js框架简明
查看>>
Java volatile 关键字
查看>>
http 头信息详解
查看>>
计算机图形学(OpenGL版)-OpenGL基本几何图元
查看>>
Oracle 12C 新特性之表分区带 异步全局索引异步维护(一次add、truncate、drop、spilt、merge多个分区)...
查看>>
Mybatis动态SQL生成
查看>>
javascript 正则表达式学习
查看>>
关于Asp.Net中避免用户连续多次点击按钮,重复提交表单的处理
查看>>
js页面刷新一次
查看>>
坑人的运算符
查看>>
spring security custom-filter with java configuration 验证码验证
查看>>
01、BootstrapperShell
查看>>
Automation Test in Maya Plugin Development
查看>>
DRM 简介
查看>>
idea编译时JDK版本变化
查看>>
搭建LoadRunner中的场景(一) 创建场景
查看>>