未经许可不允许启动服务 Intent X Y

Posted

技术标签:

【中文标题】未经许可不允许启动服务 Intent X Y【英文标题】:Not allowed to start service Intent X without permission Y 【发布时间】:2012-05-06 03:00:28 【问题描述】:
04-25 14:16:30.931: E/androidRuntime(6638): FATAL EXCEPTION: main
04-25 14:16:30.931: E/AndroidRuntime(6638): java.lang.RuntimeException: Failure delivering result ResultInfowho=null, request=1, result=-1, data=Intent  (has extras)  to activity com.exclusive26.igale/com.exclusive26.igale.Push_Activity: java.lang.SecurityException: Not allowed to start service Intent  act=com.google.android.c2dm.intent.REGISTER pkg=com.google.android.gsf (has extras)  without permission com.google.android.c2dm.permission.RECEIVE
04-25 14:16:30.931: E/AndroidRuntime(6638):     at android.app.ActivityThread.deliverResults(ActivityThread.java:2553)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at android.app.ActivityThread.handleSendResult(ActivityThread.java:2595)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at android.app.ActivityThread.access$2000(ActivityThread.java:121)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:973)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at android.os.Handler.dispatchMessage(Handler.java:99)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at android.os.Looper.loop(Looper.java:130)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at android.app.ActivityThread.main(ActivityThread.java:3701)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at java.lang.reflect.Method.invokeNative(Native Method)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at java.lang.reflect.Method.invoke(Method.java:507)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:866)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:624)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at dalvik.system.NativeStart.main(Native Method)
04-25 14:16:30.931: E/AndroidRuntime(6638): Caused by: java.lang.SecurityException: Not allowed to start service Intent  act=com.google.android.c2dm.intent.REGISTER pkg=com.google.android.gsf (has extras)  without permission com.google.android.c2dm.permission.RECEIVE
04-25 14:16:30.931: E/AndroidRuntime(6638):     at android.app.ContextImpl.startService(ContextImpl.java:867)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at android.content.ContextWrapper.startService(ContextWrapper.java:336)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at com.google.android.c2dm.C2DMessaging.register(C2DMessaging.java:54)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at com.exclusive26.igale.Push_Activity.register(Push_Activity.java:124)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at com.exclusive26.igale.Push_Activity.onActivityResult(Push_Activity.java:58)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at android.app.Activity.dispatchActivityResult(Activity.java:3908)
04-25 14:16:30.931: E/AndroidRuntime(6638):     at android.app.ActivityThread.deliverResults(ActivityThread.java:2549)
04-25 14:16:30.931: E/AndroidRuntime(6638):     ... 11 more

意图在清单中确实具有适当的权限:

清单:

<permission
    android:name="com.exclusive26.igale.permission.C2D_MESSAGE"
    android:protectionLevel="signature" />
<uses-permission android:name="com.exclusive26.igale.permission.C2D_MESSAGE"/>
<uses-permission android:name="com.exclusive26.igale.c2dm.permission.RECEIVE"/>
...
...
<activity android:name=".Push_Activity"
    android:label="@string/app_name">
    <intent-filter>
        <action android:name="android.intent.action.MAIN" />
    </intent-filter>
</activity>
...
...
<service android:name=".C2DMReceiver" />

<receiver android:name="com.google.android.c2dm.C2DMBroadcastReceiver"
    android:permission="com.google.android.c2dm.permission.SEND">

    <intent-filter>
        <action android:name="com.google.android.c2dm.intent.RECEIVE" />
        <category android:name="com.exclusive26.igale" />
    </intent-filter>

    <intent-filter>
        <action android:name="com.google.android.c2dm.intent.REGISTRATION"/> 
        <category android:name="com.exclusive26.igale" />
    </intent-filter>
</receiver>

在 Push_Activity.java 中检查出以下代码:

com.google.android.c2dm.C2DMessaging.register( this, com.exclusive26.igale.Config.C2DM_SENDER );

正确发送的参数(Push_Activity 上下文和一些电子邮件地址

public static void register(Context context,
        String senderId) 
    Intent registrationIntent = new Intent(REQUEST_REGISTRATION_INTENT);
    registrationIntent.setPackage(GSF_PACKAGE);
    registrationIntent.putExtra(EXTRA_APPLICATION_PENDING_INTENT,
            PendingIntent.getBroadcast(context, 0, new Intent(), 0));
    registrationIntent.putExtra(EXTRA_SENDER, senderId);
    context.startService(registrationIntent);
    // TODO: if intent not found, notification on need to have GSF

在 startService() 中我得到了异常。没有 idia 如何解决这个问题。 请阐明这个问题。非常感谢!

【问题讨论】:

【参考方案1】:

仅供未来出现此错误的用户使用: 清单文件应如下所示:

<permission
    android:name="YOUR_PACKAGE.permission.C2D_MESSAGE"
    android:protectionLevel="signature" />

<uses-permission android:name="YOUR_PACKAGE.permission.C2D_MESSAGE" />
<uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />

而不是

<permission
    android:name="YOUR_PACKAGE.permission.C2D_MESSAGE"
    android:protectionLevel="signature" />

<uses-permission android:name="YOUR_PACKAGE.permission.C2D_MESSAGE" />
<uses-permission android:name="YOUR_PACKAGE.permission.RECEIVE" />

我花了大约 5 个小时来找出我的项目出了什么问题 :)

【讨论】:

使用 phonegap 和 PushPlugin。有趣的是插件像上面的第一个例子一样自动设置清单,我得到了指定的错误。像第二个示例一样更改它。 以防万一,我有相同的行但顺序不同。当我像上面一样订购时,我的项目就运行了【参考方案2】:

也许我遗漏了一些东西,但错误显示“com.google.android.c2dm.permission.RECEIVE”并且清单包含“com.google.android.c2dm.permission.SEND”所以我没有看到完美匹配。

【讨论】:

我只能在receiver中定义一个'android:permission'。 或许你可以在开头添加到整体权限部分? 失败点是触发以下行时(无法调试 context.startService 中的代码): context.startService(registrationIntent); 上下文是 Push_Activity 意图包含新带有附加功能的意图: act=com.google.android.c2dm.intent.REGISTER pkg=com.google.android.gsf (has extras) 第二个附加功能是:intent.putExtra("sometxt",PendingIntent.getBroadcast(context , 0, 新意图(), 0)); - 所有这些都发送到 context.startService(intent); 我用相同的代码创建了一个新项目,用于调试目的,它可以工作!我不知道为什么我不能从我的原始项目中启动服务【参考方案3】:

代码是正确的。我创建了一个新项目,复制了代码,没有问题了

【讨论】:

【参考方案4】:

如果我们在 Activity Java 文件中错误地使用了某些资源的名称,也可能会出现此错误。我也遇到了同样的错误,但我还没有使用任何服务或权限。问题出在 onCreate() 方法的资源 ID 错误。

【讨论】:

以上是关于未经许可不允许启动服务 Intent X Y的主要内容,如果未能解决你的问题,请参考以下文章

Android 8.0:java.lang.IllegalStateException:不允许启动服务 Intent

无法恢复活动:不允许启动服务 Intent,应用程序在后台

FCM 致命异常:java.lang.IllegalStateException 不允许启动服务 Intent

android 在5.0以后不允许使用隐式Intent方式来启动Service

Spring Boot的启动器Starter详解

java.lang.SecurityException-不允许启动活动 Intent flg=0x4000000 cmp=[MY_ACTIVITY] (has extras)