android bindService打开失败

在写demo验证SurfaceControlViewHost的时候,bindService提示

Unable to start service Intent U=0: not found

在源代码里搜了下,找到是在如下方法里面里面打印出来的

java 复制代码
// frameworks/base/services/core/java/com/android/server/am/ActiveServices.java
retrieveServiceLocked {
    ....
    if(mAm.getPackageManagerInternal().filterAppAccess(r.packageName,callingUid,
        userId)){
        Slog.w(TAG_SERVICE,"Unable to start service "+service+" U="+userId
        +": not found");
        returnnull;
    }
    ....
}

后面查了下,发现是包可见性的变更引起的异常

Android 11 中的软件包可见性 | Android Developers
Android 上的软件包可见性过滤 | Android Developers

解决方案,在使用的bindService的应用的AndroidManifest.xml里面加上queries,类似如下

java 复制代码
    <queries>
        <package android:name="com.example.host"/>
    </queries>
相关推荐
e***87704 小时前
windows配置永久路由
android·前端·后端
fouryears_234175 小时前
现代 Android 后台应用读取剪贴板最佳实践
android·前端·flutter·dart
YF02116 小时前
Frida for MacBook/Android 安装配置
android·前端
雨白7 小时前
Android实战:构建高可维护的日志系统
android
茄子凉心8 小时前
android 开机启动App
android·java·开发语言
2501_9371931410 小时前
神马影视 8.8 版源码:4K 播放优化体验测评
android·源码·源代码管理·机顶盒
修炼者11 小时前
Kotlin中的Flow流
android·kotlin
洞见不一样的自己12 小时前
Android studio 编译问题
android
j***630812 小时前
SpringbootActuator未授权访问漏洞
android·前端·后端
YJlio12 小时前
进程和诊断工具学习笔记(8.29):ListDLLs——一眼看清进程里加载了哪些 DLL,谁在偷偷注入
android·笔记·学习