无线页面远程调试方式的演进探索

如果无法正常显示,请先停止浏览器的去广告插件。
分享至:
1.
2. 线 远程调试 演进探索 式的
3. 录 案演进
4. 1. 端内 线 调试的困境
5. 线
6. 主流 般都需要基于 Debug 包
7. 主流 Eruda
8. 主流 线 weinre 系 调试 案的问题 案 weinre is WEb INspector REmote
9. 主流 有限 基于 线 络传输通道的远程调试架构 纯前端可以实现基础能 的远程调试
10. 主流 动注 JS 脚本 spy-debugger
11. 调试 我们需要怎样的 线 案?
12. 2. 线 调试 案的演进
13. 线 建设 案
14. 效果演示
15. 线 JS 的 CDP 模拟实现 案
16. 基于注 JS 的 CDP 模拟实现 案 什么是 CDP { Chrome DevTools Protocol:JSON 类型的固定格 式的数据封装协议,基于该协议能够实现 DevTools 与 Blink-based(Chrome/Chromium 等)浏览器 内核的交互,达到检测、检查、调试和分析浏览器 内核的能 。 “id”:1, “method":"Network.enable", “params”: { “maxPostDataSize”: 65536 } }
17. 基于注 JS 的 CDP 模拟实现 案 CDP 通信示例 浏览器内核 DevTools {“id”:1, “method”:“Runtime.enable”} Request {“id”:2, “method”:“Debugger.enable”, “params”: {“maxScriptsCacheSize”: 1000000}} Response {“id”:1, “result”:{}} {“id”:2, “result”:{}} {“method”:"Network.loadingFinished","params": {"requestId":"8358.1","timestamp":1700061910}} Event
18. 基于注 JS 的 CDP 模拟实现 案 整体架构 PC 浏览器 APP DevTools Frontend WebView Page Panels CDP WS Server CDP Client CDP backend.js 注
19. 基于注 脚本
20. 基于注 send listen disconnect
21. 基于注 案
22. 基于注 ‣ 不 持断点调试 ‣ Network 数据缺失 ‣ 法获取偏底层的 Memory 等数据 ‣ 法使 Lighthouse ‣ 。。。
23. 基于注 JS 的 CDP 模拟实现 案 插件机制 Inspected window Content scripts DevTools page Panels Chrome Extension Custom Extension
24. 基于注 插件使 JS 的 CDP 模拟实现 示例 DevTools page {“id”:1, “method”:“getEnv”} getEnv {“id”:1, “result”: {envInfo}} envInfo react-devtools-inline/ backend Native API content script react-devtools-inline/ frontend 案
25. 线 案
26. 基于内核的标准调试 案 整体架构 PC 浏览器 APP Chrome DevTools Frontend UC U4 Page CDP Client Android Panels CDP CDP WS Server WebKit Web Inspector CDP Client Panels WIP WIP WebKit Page iOS
27. 基于内核的标准调试 案 Android USB 调试原理 /json/list Unix Domain Socket Server CDP adb CDP Chrome DevTools CDP socket client
28. 基于内核的标准调试 案 Android Chrome DevTools Frontend 标准内核 标准内核 增强内核 APP APP UC U4 get webview list 开启调试 远程下载 WS Server webview list inspect webview A with ws inspector url inspect webview A with ws target url 动态切核 增强内核 APP connect ws inspector url connect ws target url
29. 基于内核的标准调试 Android 示例 案
30. 基于内核的标准调试 案 WS Server iOS APP 连接本地代理的内核通道和 WS Server Remote Inspector Native Bridge WebKit 内核 inspector WKWebView Page 建 与内核通信的通道,代理 Debugger 实例 WebKit 内核 Debugger 实例
31. 基于内核的标准调试 iOS 示例 案
32. 基于内核的标准调试 案 容器接 PC 浏览器 APP Other Engine Weex CDP DevTools Frontend WS Server CDP Page WebView Page
33. 基于内核的标准调试 案 WS Server Page 1 debugId sessionId 1 sessionId 1 DevTools 1 Page 2 sessionId 2 sessionId 2 DevTools 2 Page 3 sessionId 3 sessionId 3 DevTools 3 debugId WS Server /page/:debugId/:sessionId /devtools/:debugId/:sessionId
34. 线 建设
35. 结合客户端的配套调试能 建设 实时 志 缓存管理 开启 线 调试 性能数据 … 客户端调试
36. 结合客户端的配套调试能 建设 志 实时
37. 结合客户端的配套调试能 建设 缓存管理
38. 结合客户端的配套调试能 建设 性能数据
39. 3. 总结与展望
40. 总结
41. 展望
42. THANK YOU

首页 - Wiki
Copyright © 2011-2025 iteam. Current version is 2.142.1. UTC+08:00, 2025-04-04 11:17
浙ICP备14020137号-1 $访客地图$