遍历 AccessibilityNodeInfo 报 StackOverflowError
在使用 AccessibilityService 遍历包含 WebView 的 AccessibilityNodeInfo 时会在某些情况下必现 StackOverflowError
的错误,导致应用崩溃。
0x00 异常
最近使用 Android 的 AccessibilityService 做一些自动化操作时发现,在部分机器上遍历包含 WebView 页面的 AccessibilityNodeInfo 时,某些页面必定会引起 StackOverflowError
错误,经过一番查证,定位到主要与系统所使用的 Android System WebView 版本有关,属于 WebView 的 Bug。
相关说明可以参考 Android: Infinite loop of FrameLayouts in accessibility tree 的讨论。
查看 Android System WebView 版本(以下2种方法任一均可):
- 应用程序
- 菜单:显示系统应用程序
- 点击列表中的:Android System WebView
- 详情页内包含版本
- 开发者选项
- 开启「开发者选项」
- 开发者选项 -> WebView 实现
0x01 解决
方法有2种:
- 一个是尝试在 Google Play Store 中升级 Android System WebView 到最新版;
- 一个是使用递归遍历 AccessibilityNodeInfo 时限制遍历的最大深度,这个深度根据情况大致在 40~70之间即可,既要基本保证能遍历完正常的 NodeTree 内的 Node,又要不引起
StackOverflowError
导致应用崩溃。
当然,方法2更具有可控性和兼容性,某些情况下我们并不能左右用户手机上 Android System WebView 的版本。
0x02 总结
此类情况发生在特定的 Android System WebView 和 Android 版本上,建议使用了相关功能的应用加上 Bug 上报的功能。
如果有什么建议或者问题可以随时联系我,共同探讨学习: