AccessibilityService微信自动化节点元素混淆问题解决

问题背景

AccessibilityService获取微信版本8.0.52以上的节点元素时信息会被混淆打乱,导致无法正常执行AccessibilityService自动化逻辑,这个问题直接影响自动化脚本对于后面微信版本的兼容。

解决

在自动化开源库Assists有网友提了这个关于微信的issues,最终也是他提供的解决方法:

创建注册一个与系统内置的相同包名类名的无障碍服务,比如:com.google.android.marvin.talkback.TalkBackService

最终通过验证确实可以👍

但是发现开启这个服务后小米手机屏幕上一直显示两行文字:

因为com.google.android.marvin.talkback.TalkBackService是Android系统自带的屏幕阅读器服务所以开启后会一直显示这两行文字

解决办法是可以定义其他系统无障碍服务相同包名类名的服务,比如:com.google.android.accessibility.selecttospeak.SelectToSpeakService

Assists中已经定义好了这个服务,集成这个库然后直接在自己的主模块中注册这个服务来使用即可

ini 复制代码
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    package="com.ven.assists.simple">
    <application
        android:name="com.ven.assists.simple.App"
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:requestLegacyExternalStorage="true"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme"
        android:usesCleartextTraffic="true">
        <!-- 注册下面的服务-->
        <service
            android:name="com.google.android.accessibility.selecttospeak.SelectToSpeakService"
            android:enabled="true"
            android:exported="true"
            android:permission="android.permission.BIND_ACCESSIBILITY_SERVICE">
            <!--android:priority="10000" 可提高服务在设置中的权重,排在前面     -->
            <intent-filter android:priority="10000">
                <action android:name="android.accessibilityservice.AccessibilityService" />
            </intent-filter>
            <meta-data
                android:name="android.accessibilityservice"
                android:resource="@xml/assists_service" />
        </service>
    </application>

</manifest>
相关推荐
vim怎么退出21 分钟前
谷歌性能优化知识点总结
前端
专业抄代码选手23 分钟前
在react中,TSX是如何转变成JS的
前端·javascript
葡萄城技术团队23 分钟前
【实践篇】从零到一:手把手教你搭建一套企业级 SpreadJS 协同设计器
前端
忆江南1 小时前
# iOS Block 深度解析
前端
米丘1 小时前
vue-router v5.x 路由模式关于 createWebHistory、 createWebHashHistory的实现
前端
本末倒置1831 小时前
Bun 内置模块全解析:告别第三方依赖,提升开发效率
前端·javascript·node.js
踩着两条虫1 小时前
AI 驱动的 Vue3 应用开发平台 深入探究(二):核心概念之DSL模式与数据模型
前端·vue.js·ai编程
牛奶1 小时前
200 OK不是"成功"?HTTP状态码潜规则
前端·http·浏览器
Hilaku2 小时前
OpenClaw 很爆火,但没人敢聊它的权限安全🤷‍♂️
前端·javascript·程序员
ConardLi3 小时前
OpenClaw 完全指南:这可能是全网最新最全的系统化教程了!
前端·人工智能·后端