一个由API level引发的惨案
概述
一句话描述:Android 8.0 (API level 26)开始无法使用AndroidManifest为绝大多数隐式广播(不针对您的应用程序的广播)声明接收者。
Beginning with Android 8.0 (API level 26), the system imposes additional restrictions on manifest-declared receivers. If your app targets API level 26 or higher, you cannot use the manifest to declare a receiver for most implicit broadcasts (broadcasts that do not target your app specifically).
全文链接 Broadcasts
详情
起因
今天跟着《第二行代码》学安卓,敲到5.3.1的代码发送自定义广播时怎么也出不来结果,也没有任何报错信息。于是就开始了一晚上的debug过程。。。
(加些关键字给某度 静态广播失效 android广播收不到 第一行代码)
经过
先后使用了修改接收器,加断点调试和adb shell查看pms信息都没发现什么问题,然后在郭霖大神的GitHub上download了第二行安卓的源代码运行后发现没有任何问题,一切都跑的那么完美。。。最后意识到API level不一样他用的24我用最新的是26,于是修改build文件后run一切ok~
结果
发现这个后就针性地进行了搜索(关键词api 26 can’t register broadcast in manifest)第一条就是上文~
总结
虽然花了一晚上时间搞这个bug(也不算浪费时间吧,毕竟debug的过程中也学好了好多东西,比如静态广播动态广播区别,比如adb shell黑魔法。。。)但最后能解决至少是个happy ending~
解决
- 使用动态广播代替静态广播(代码略)
- 发送广播时加入Component参数
Intent intent = new Intent("xxx"); //xxx:action的name
intent.setComponent(new ComponentName("aaa", "aaa.bbb")); // aaa:包名 bbb:类名
sendBroadcast(intent);