Android 11 Unable to start/bind service

今天在Android11上发现了一个的问题,如果目标Service的进程没有启动,那么无论是bindService还是startService都没有办法拉起指定的Service。

网上查了很多资料如下:

1.目标Service 设置 android:exported="true"

2.目标Service需要声明自定义权限。客户端需要声明权限。

3.目标Service需要添加<intent-filter></intent-filter>

上面的方法都试过了**然并卵**,还是报Unable to start service Intent.

实在没办法去翻了下源码~在startService中过程中当调用调用pms去解析intent是返回null会打印这个日志。代码片段如下~

java 复制代码
ActiveServices # retrieveServiceLocked     ResolveInfo rInfo = mAm.getPackageManagerInternalLocked().resolveService(service,
                        resolvedType, flags, userId, callingUid);
     ServiceInfo sInfo = rInfo != null ? rInfo.serviceInfo : null;
     if (sInfo == null) {
         Slog.w(TAG_SERVICE, "Unable to start service " + service + " U=" + userId +
                          ": not found");
          return null;
     }

//....代码省略

java 复制代码
PackageManagerService # resolveServiceInternal

    private ResolveInfo resolveServiceInternal(Intent intent, String resolvedType, int flags,
            int userId, int callingUid) {
        if (!mUserManager.exists(userId)) return null;
        flags = updateFlagsForResolve(flags, userId, callingUid, false /*includeInstantApps*/,
                false /* isImplicitImageCaptureIntentAndNotSetByDpc */);
        List<ResolveInfo> query = queryIntentServicesInternal(
                intent, resolvedType, flags, userId, callingUid, false /*includeInstantApps*/);
        if (query != null) {
            if (query.size() >= 1) {
                // If there is more than one service with the same priority,
                // just arbitrarily pick the first one.
                return query.get(0);
            }
        }
        return null;
    }

看到上面源码吓的我赶紧搜了搜Android11 resolveIntent返回null的问题~

果然不出所料,Android 11引入了*包可见性*

为啥引入包可见性呢?

Goole给出的原因:

1.鼓励最小权限原则,需要与那些应用交互,就申请那些包名。

2.帮助 Google Play 等应用商店评估应用的隐私性和安全性。、

好啦,知道了前因后果那么我们来解决问题吧~

Solve方案

方案一:

java 复制代码
<queries>
        //你要交互的service的包名
        <package android:name="com.XXX.XXX" />
        //...等等包名
</queries>

方案二:

java 复制代码
<uses-permission android:name="android.permission.QUERY_ALL_PACKAGES"/>

配置完了,赶紧拿起手机试了试,重启手机~bind目标service,终于bind成功了~

上面的包可见性问题不仅Service有这个问题,Activity也有这么问题哈,记录一下,避免有朋友也遇到同样的问题。

相关推荐
娅娅梨4 小时前
Android- Surface, SurfaceView, TextureView, SurfaceTexture 原理图解
android·surface
2501_915918416 小时前
HTTPS 端口号详解 443 端口作用、iOS 抓包方法、常见 HTTPS 抓包工具与网络调试实践
android·网络·ios·小程序·https·uni-app·iphone
程序员码歌6 小时前
明年35岁了,如何破局?说说心里话
android·前端·后端
非门由也8 小时前
Android studio安装教程——超详细(含安装包安装教程)
android·ide·android studio
平淡风云8 小时前
Android应用添加日历提醒功能
android·日历
骐骥19 小时前
2025-09-08升级问题记录:app提示“此应用专为旧版Android打造..”或“此应用与最新版 Android 不兼容”
android·升级·不兼容·target sdk·专为旧版 android 系统
Zender Han9 小时前
Flutter 视频播放器——flick_video_player 介绍与使用
android·flutter·ios·音视频
尚久龙10 小时前
安卓学习 之 用户登录界面的简单实现
android·运维·服务器·学习·手机·android studio·安卓
Modu_MrLiu11 小时前
Android实战进阶 - 启动页
android·实战进阶·启动页·倒计时场景
出门吃三碗饭11 小时前
编译器构造:从零手写汇编与反汇编程序(一)
android·汇编