今天在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会打印这个日志。代码片段如下~
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;
}
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 ,
false );
List<ResolveInfo> query = queryIntentServicesInternal(
intent, resolvedType, flags, userId, callingUid, false );
if (query != null) {
if (query.size() >= 1) {
return query.get(0);
}
}
return null;
}
看到上面源码吓的我赶紧搜了搜Android11 resolveIntent返回null的问题~ 果然不出所料,Android 11引入了*包可见性* 为啥引入包可见性呢? Goole给出的原因: 1.鼓励最小权限原则,需要与那些应用交互,就申请那些包名。 2.帮助 Google Play 等应用商店评估应用的隐私性和安全性。、
好啦,知道了前因后果那么我们来解决问题吧~
Solve方案
方案一:
<queries>
<package android:name="com.XXX.XXX" />
</queries>
方案二:
<uses-permission android:name="android.permission.QUERY_ALL_PACKAGES"/>
配置完了,赶紧拿起手机试了试,重启手机~bind目标service,终于bind成功了~ 上面的包可见性问题不仅Service有这个问题,Activity也有这么问题哈,记录一下,避免有朋友也遇到同样的问题。
|