我的Android进阶之旅------>如何解决Android 5.0中出现的警告: Service Intent must be explicit:..._weixin_34037515的博客-程序员宅基地

我的Android进阶之旅——>如何解决Android 5.0中出现的警告: java.lang.IllegalArgumentException: Service Intent must be explicit: Intent { act=com.xtc.kuwo.watch.MUSIC_PLAY_SERVICE (has extras) }

1.错误描述

今天在Android4.4 的小米4手机上运行我的程序的时候没有报错,而在Android 5.1的华为P7上运行我的程序的时候报了以下的错误,错误提示如下:

E/AndroidRuntime(12500): FATAL EXCEPTION: main
E/AndroidRuntime(12500): Process: com.xtc.watch, PID: 12500
E/AndroidRuntime(12500): java.lang.IllegalArgumentException: Service Intent must be explicit: Intent { act=com.xtc.kuwo.watch.MUSIC_PLAY_SERVICE (has extras) }
E/AndroidRuntime(12500):        at android.app.ContextImpl.validateServiceIntent(ContextImpl.java:1847)
E/AndroidRuntime(12500):        at android.app.ContextImpl.startServiceCommon(ContextImpl.java:1876)
E/AndroidRuntime(12500):        at android.app.ContextImpl.startService(ContextImpl.java:1860)
E/AndroidRuntime(12500):        at android.content.ContextWrapper.startService(ContextWrapper.java:516)
E/AndroidRuntime(12500):        at com.xtc.watch.kuwo.activity.WatchMusicPlay.pauseMusic(WatchMusicPlay.java:314)
E/AndroidRuntime(12500):        at com.xtc.watch.kuwo.activity.WatchMusicPlay.access$600(WatchMusicPlay.java:32)
E/AndroidRuntime(12500):        at com.xtc.watch.kuwo.activity.WatchMusicPlay$3.onClick(WatchMusicPlay.java:220)
E/AndroidRuntime(12500):        at android.view.View.performClick(View.java:4790)
E/AndroidRuntime(12500):        at android.view.View$PerformClick.run(View.java:19933)
E/AndroidRuntime(12500):        at android.os.Handler.handleCallback(Handler.java:739)
E/AndroidRuntime(12500):        at android.os.Handler.dispatchMessage(Handler.java:95)
E/AndroidRuntime(12500):        at android.os.Looper.loop(Looper.java:135)
E/AndroidRuntime(12500):        at android.app.ActivityThread.main(ActivityThread.java:5569)
E/AndroidRuntime(12500):        at java.lang.reflect.Method.invoke(Native Method)
E/AndroidRuntime(12500):        at java.lang.reflect.Method.invoke(Method.java:372)
E/AndroidRuntime(12500):        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:931)
E/AndroidRuntime(12500):        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:726)

这里写图片描述

而我启动Service的Intent代码如下所示:

        Intent intent = new Intent();
        intent.setAction(MUSIC_PLAY_SERVICE);
        intent.putExtra("MSG", Constants.PlayerMsg.PAUSE_MSG);  //暂停播放音乐
        intent.putExtra("musicURL", musicURL);  //歌曲URL
        startService(intent);

2.错误原因

有些时候我们使用Service的时需要采用隐私启动的方式,但是Android 5.0一出来后,其中有个特性就是Service Intent must be explitict,也就是说从Android Lollipop版本(Android 5.0)开始,service服务必须采用显示方式启动。

而android源码是这样写的(源码位置:sdk/sources/android-21/android/app/ContextImpl.java):

startService(Intent service)方法

startService(Intent service)方法代码如下

 @Override
    public ComponentName startService(Intent service) {
        warnIfCallingFromSystemProcess();
        return startServiceCommon(service, mUser);
    }

startServiceCommon(Intent service, UserHandle user)方法

上面的startService(Intent service)方法调用的是startServiceCommon(Intent service, UserHandle user),代码如下所示:

 private ComponentName startServiceCommon(Intent service, UserHandle user) {
        try {
            validateServiceIntent(service);
            service.prepareToLeaveProcess();
            ComponentName cn = ActivityManagerNative.getDefault().startService(
                mMainThread.getApplicationThread(), service,
                service.resolveTypeIfNeeded(getContentResolver()), user.getIdentifier());
            if (cn != null) {
                if (cn.getPackageName().equals("!")) {
                    throw new SecurityException(
                            "Not allowed to start service " + service
                            + " without permission " + cn.getClassName());
                } else if (cn.getPackageName().equals("!!")) {
                    throw new SecurityException(
                            "Unable to start service " + service
                            + ": " + cn.getClassName());
                }
            }
            return cn;
        } catch (RemoteException e) {
            return null;
        }
    }

validateServiceIntent(Intent service)方法

上面的startServiceCommon(Intent service, UserHandle user)方法中调用的validateServiceIntent(Intent service)方法代码如下所示:

 private void validateServiceIntent(Intent service) {
        if (service.getComponent() == null && service.getPackage() == null) {
            if (getApplicationInfo().targetSdkVersion >= Build.VERSION_CODES.LOLLIPOP) {
                IllegalArgumentException ex = new IllegalArgumentException(
                        "Service Intent must be explicit: " + service);
                throw ex;
            } else {
                Log.w(TAG, "Implicit intents with startService are not safe: " + service
                        + " " + Debug.getCallers(2, 3));
            }
        }
    }

可以看得出来,就是在validateServiceIntent(Intent service)方法中判断如果大于Build.VERSION_CODES.LOLLIPOP版本的话,并且启动Service的Intent如果没有设置Component和Package的话就会跑出异常java.lang.IllegalArgumentException: Service Intent must be explicit:

版权声明:本文为【欧阳鹏】原创文章,欢迎转载,转载请注明出处!
http://blog.csdn.net/ouyang_peng/article/details/50727693

3.解决方法

设置要启动Service的Intent的Action和packageName

        Intent intent = new Intent();
        intent.setAction(MUSIC_PLAY_SERVICE);
        intent.putExtra("MSG", Constants.PlayerMsg.PAUSE_MSG);  //暂停播放音乐
        intent.putExtra("musicURL", musicURL);  //歌曲URL
        startService(intent);

这里写图片描述

改为:

        Intent intent = new Intent();
        intent.setAction(MUSIC_PLAY_SERVICE);
        //不加这句话的话 android 5.0以上会报:Service Intent must be explitict
        intent.setPackage(getPackageName());
        intent.putExtra("MSG", Constants.PlayerMsg.PAUSE_MSG);  //暂停播放音乐
        intent.putExtra("musicURL", musicURL);  //歌曲URL
        startService(intent);

这里写图片描述

以上代码就是加了一行

        //不加这句话的话 android 5.0以上会报:Service Intent must be explitict
        intent.setPackage(getPackageName());

此方式是google官方推荐使用的解决方法。

在此附上地址供大家参考:http://developer.android.com/goo … tml#billing-service,有兴趣的可以去看看。

下面是http://developer.android.com/goo … tml#billing-service网站的截图,如下所示:

google官方网站上的提示

版权声明:本文为【欧阳鹏】原创文章,欢迎转载,转载请注明出处!
http://blog.csdn.net/ouyang_peng/article/details/50727693

作者:欧阳鹏 欢迎转载,与人分享是进步的源泉!
转载请保留原文地址:http://blog.csdn.net/ouyang_peng

这里写图片描述

转载于:https://www.cnblogs.com/ouyangpeng/p/8537794.html

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_34037515/article/details/94208281

智能推荐

0-zookeeper之Linux系统安装zookeeper_weixin_44377171的博客-程序员宅基地

0. Linux系统安装zookeeper安装zookeeper之前,先把jdk安装好安装指导https://www.cnblogs.com/sea520/p/13500978.htmlhttps://www.cnblogs.com/lsdb/p/7297731.html下载地址https://zookeeper.apache.org/ ,记住下载bin包,否则会启动不了程序,相关错误可见章节4、安装常见问题 1下载后,上传到服务器指定目录 /root/soft/zook

vue事项元素滑动顶部吸顶_wei80231996的博客-程序员宅基地

1.html<ui id="searchBar"> <li>1234354</li> <li>1234354</li> <li>1234354</li> <li>1234354</li> <li>1234354</li> <li>1234354</li> <li>1234354</li> <li&gt

linux日志字体为蓝色,解决在linux字体下的显示问题及几种办法_打喷嚏的apple的博客-程序员宅基地

一、将windows系统下的字体拷贝到linux下将WINDOWS下的C:\WINDOWS\Fonts下的SIMSUN.TTC拷贝到linux下的/usr/share/fonts/TrueType/路径下,重启linux,让系统加载该字体即可,这样就能解决绝大多数字体问题。注意:这里放置完字体后要重启系统,让系统加载字体,否则设置无效。也可以不重启系统,通过命令强制加载字体。在终端运行命令:sud...

数据传递的问题,求帮助!!!!!!!!!!!!!!_baidu_31199339的博客-程序员宅基地

前台一个表格,里边最多可以输5行数据,这个表格的模板输出出来的时候必须是5行,前台输入的数据传给后台,后台再传给模板,模板里边怎么获取数据

qtcreator_a932432866的专栏-程序员宅基地

1.提高qtcreator 编译速度    项目-》构建和运行-》构建步骤-》make详情-》make参数 ,填入-j4,之后编译就飕飕的了,如果处理器八个核填-j8

MyBatis3 用log4j在控制台输出 SQL_weixin_33795093的博客-程序员宅基地

为什么要在控制台输出 SQL 呢?当然是为了开发调试的时候方便了。如果一个 数据库相关的操作出现了问题,我们可以根据输出的SQL语句快速排查问题。输出的信息:[org.mybatis.spring.SqlSessionUtils]-Creating a new SqlSession[org.mybatis.spring.SqlSessionU...

随便推点

Struts2框架在MyEclipse中的配置_weixin_34112181的博客-程序员宅基地

为什么80%的码农都做不了架构师?>>> ...

关于计算机网络协议 下面说法错误的是,关于计算机网络协议,下面说法错误的是____..._日本狸猫田中裕之的博客-程序员宅基地

相关题目与解析关于计算机网络协议,下面说法错误的是____下面有关计算机网络的说法,错误的是()下列关于TCP/IP协议说法错误的是()。A.TCP/IP协议是计算机世界中通用的网络协议B.TCP/IP协议是I●认证是防止(62)攻击的重要技术。下面关于认证技术的说法中错误的是(63)。用户A通过计算机网络关于计算机互联网设备的叙述中,()说法是错误的。下列关于Internet的说法错误的是()。...

linux执行脚本中方法,Linux中执行shell脚本命令的4种方法总结_有信支付的博客-程序员宅基地

bash shell 脚本的方法有多种,现在作个小结。假设我们编写好的shell脚本的文件名为hello.sh,文件位置在/data/shell目录中并已有执行权限。方法一:切换到shell脚本所在的目录(此时,称为工作目录)执行shell脚本:复制代码 代码如下:cd /data/shell./hello.sh./的意思是说在当前的工作目录下执行hello.sh。如果不加上./,bash可能会响...

HDU--1576 A/B 拓展欧几里得求逆元_FLY的博客-程序员宅基地

原题链接:传送门Description要求(A/B)%9973,但由于A很大,我们只给出n(n=A%9973)(我们给定的A必能被B整除,且gcd(B,9973) = 1)。Input数据的第一行是一个T,表示有T组数据。每组数据有两个数n(0 <= n < 9973)和B(1 <= B <= 10^9)。Output对应每组数据输出(A/B)%9973...

基于设备树的TQ2440的中断(1)_weixin_33777877的博客-程序员宅基地

作者姓名:彭东林E-mail:[email protected]:405728433 平台板子:TQ2440内核:Linux-4.9u-boot: 2015.04工具链: arm-none-linux-gnueabi-gcc 4.8.3 概述在博文讓TQ2440也用上設備樹(1)将支持devicetree的Linux4.9移植到了tq2...

java面向对象程序设计第四版_Java面向对象程序设计(第4版新编高等院校计算机科学与技术规划教材)..._止部的博客-程序员宅基地

导语内容提要张桂珠主编的《Java面向对象程序设计(第4版)》是Java面向对象程序设计的一本经典教材,它将Java语言与面向对象程序设计的原理和方法相结合,使用Java最新类库,以大量实例详细介绍如何使用Java进行面向对象的程序设计、GUI的程序设计、网络通信应用的程序设计、数据库应用的程序设计和Web应用的程序设计。本书可作为Java面向对象程序设计课程的教材,也可作为Java的GUI程序设...

推荐文章

热门文章

相关标签