Android R 使用aidl进行IPC跨进程通信失败,日志显示AppsFilter: interaction: PackageSetting ... BLOCKED

本文主要是介绍Android R 使用aidl进行IPC跨进程通信失败,日志显示AppsFilter: interaction: PackageSetting ... BLOCKED,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

官方解决案例(节选)在这里插入图片描述

下面详细分析

一、 问题

使用Android R,在编写使用AIDL进行跨进程通信连接服务过程时,使用远端服务时报错。
在这里插入图片描述

2020-10-28 18:26:21.721 19025-19025/com.practice.ipcclient
E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.practice.ipcclient, PID: 19025
java.lang.NullPointerException: Attempt to invoke interface method ‘void
com.practice.ipcserver.IStudentManager.addStudent(com.practice.ipcserver.entity.Student)’
on a null object reference

这个空对象让人摸不着头脑,猜测

  1. intent属性设置错误,即包名类名Action等信息。反复修改双方约定的对应属性仍无法解决
  2. 服务是否连接成功的影响。结果发现bindService()返回false,说明但是没有连接上服务,但是不会报错,朋友帮助跟踪日志才知道是新版本的功能限制(没点经验还真不知道AppsFilter: interaction: PackageSetting ... BLOCKED这个是错误)

二、分析

  • build.gradle:配置Android R最新版本
android {compileSdkVersion 30buildToolsVersion '30.0.2'defaultConfig {applicationId "com.practice.ipcclient"minSdkVersion 30targetSdkVersion 30versionCode 1versionName "1.0".....}.....
}
  • 日志:adb logcat -b all -vtime打印

10-28 15:57:53.922 I/AppsFilter( 1089): interaction: PackageSetting{1a80770 com.practice.ipcclient/10245} -> PackageSetting{d264a04 com.practice.ipcserver/10247} BLOCKED
10-28 15:57:53.922 W/ActivityManager( 1089): Unable to start service Intent { act=com.practice.ipcserver.action cmp=com.practice.ipcserver/.StudentManagerService } U=0: not found
10-28 15:57:53.922 I/MainActivity( 4674): [onClick]bind stu_service end false,intent info:ComponentInfo{com.practice.ipcserver/com.practice.ipcserver.StudentManagerService}

三、 解决

(一)最简单:降低SDK版本

  • 修改build.gradle,降低SDK版本为Android 29

(二)修改软件可见性

在AndroidManifest.xml中添加queries标签声明需要用到的应用包名(还可以通过intent或者provider——参考1)

  • 在跨进程调用方声明使用的对方即可,无需双方声明。
<!--IPCServer-->
<queries><package android:name="com.practice.ipcclient" />
</queries><!--IPCClient-->
<queries><package android:name="com.practice.ipcserver" />
</queries>
问题
  1. AndroidManifest.xml中无法使用queries标签。
  • 本质gradle编译插件太低级
  • AndroidStudio4.1之前还没有支持这个标签(参考2)

在这里插入图片描述

>  Task :ipcclientpractice:processDebugManifest FAILED ipcclientpractice\src\main\AndroidManifest.xml:5:9-58
> Error: 	Missing 'package' key attribute on element package at
> AndroidManifest.xml:5:9-58
> \ipcclientpractice\src\main\AndroidManifest.xml
> Error: 	Validation failed, exiting
> 
> See [http://g.co/androidstudio/manifest-merger](http://g.co/androidstudio/manifest-merger) for more information
> about the manifest merger.
> 
> 
> FAILURE: Build failed with an exception.
> 
> * What went wrong: Execution failed for task ':ipcclientpractice:processDebugManifest'.
>  Manifest merger failed with multiple errors, see logs
> 
> * Try: Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output. Run with --scan to get full insights.
> 
> * Get more help at [https://help.gradle.org](https://help.gradle.org)
> 
> BUILD FAILED in 1s 9 actionable tasks: 1 executed, 8 up-to-date

在这里插入图片描述

  • 解决:升级AS到4.1+,并更新build gradle插件(缺一不可),否则报错如下

This version of the Android Support plugin for IntelliJ IDEA (or Android Studio) cannot open this project, please retry with version 4.1 or newer.

在这里插入图片描述
在这里插入图片描述

参考
  1. 官方文档:管理软件包可见性https://developer.android.google.cn/training/basics/intents/package-visibility
    (表明Android11对应用可见性的默认约定)

    If your app targets Android 11 (API level 30) or higher, the system makes some apps visible to your app automatically, but it hides other apps by default.
    如果您的应用定位到Android 11(API级别30)或更高版本,则系统会自动使某些应用对您的应用可见,但默认情况下会隐藏其他应用。

    If your app targets Android 11 (API level 30) or higher and needs to
    interact with apps other than the ones that are visible automatically,
    add the queries element in your app’s manifest file. Within the
    queries element, specify the other apps by package name, by intent
    signature, or by provider authority
    如果您的应用定位到Android 11(API级别30)或更高版本,并且需要与除自动显示的应用以外的其他应用进行交互,请queries在应用的清单文件中添加元素。在queries元素内,按照包名,intent签名或provider授权来指定其他应用

    【日志过滤工具】在Android Studio中开发测试应用程序或可调试应用程序,则将为您启用此功能
    在这里插入图片描述

    PS:developer.android.com无法访问时,可以用developer.android.google.cn替换

  2. Android Studio 4.1 的一些更新支持https://android-developers.googleblog.com/2020/10/android-studio-41.html(解决query标签在Android Studio不可用问题)

这篇关于Android R 使用aidl进行IPC跨进程通信失败,日志显示AppsFilter: interaction: PackageSetting ... BLOCKED的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/420836

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma