【问题标题】:WakefulBroadcastReceiver onReceive not triggering android GCMWakefulBroadcastReceiver onReceive 未触发 android GCM
【发布时间】:2015-01-31 13:06:43
【问题描述】:

我在 Android 中实现了GCM 通知,一切正常。我正在使用 Google 云消息服务通过 PHP 服务器向手机发送通知。
大约一周后,我在手机上再次安装了该应用程序,并向手机发送了测试通知,但我什么也没收到。 PHP 脚本运行时没有任何错误,success=1 和 GCM 响应中没有 cononical id。 WakufulBroadcastReceiver 不会在 Android 应用中触发。

这是我正在使用的完整代码:

GcmBroadcastReceiver.java

public class GcmBroadcastReceiver extends WakefulBroadcastReceiver{
    @Override
    public void onReceive(Context context, Intent intent) {
        Log.d("", "In Receive Method of Broadcast Receiver");
        ComponentName cn = new ComponentName(context.getPackageName(), GcmMessageHandler.class.getName());
        startWakefulService(context, intent.setComponent(cn));
        setResultCode(Activity.RESULT_OK);
    }
}

GcmMessageHandler.java

public class GcmMessageHandler extends IntentService{

    Handler handler;
    public GcmMessageHandler() {
        super("GcmMessageHandler");
        // TODO Auto-generated constructor stub
    }
    public GcmMessageHandler(String name) {
        super("GcmMessageHandler");
    }

    @Override
    public void onCreate() {
        super.onCreate();
        handler = new Handler();
    }

    @Override
    protected void onHandleIntent(Intent intent) {
        GoogleCloudMessaging gcm = GoogleCloudMessaging.getInstance(this);
        String messageType = gcm.getMessageType(intent);
        final String message = intent.getExtras().getString("name");
         Log.d("GCM", "Received : (" +messageType+")  "+intent.getExtras().getString("name"));
        handler.post(new Runnable() {

            @Override
            public void run() {
                Toast.makeText(getApplicationContext(), message, Toast.LENGTH_LONG).show();
            }
        });
        GcmBroadcastReceiver.completeWakefulIntent(intent);

    }

}

Manifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.test_push_app"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="21" />

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.GET_ACCOUNTS" />
    <uses-permission android:name="android.permission.WAKE_LOCK" />
    <uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />
    <permission
        android:name="com.example.test_push_app.permission.C2D_MESSAGE"
        android:protectionLevel="signature" />
    <uses-permission android:name="com.example.test_push_app.permission.C2D_MESSAGE" />


    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" >
        <activity
            android:name=".MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <receiver
            android:name=".GcmBroadcastReceiver"
            android:permission="com.google.android.c2dm.permission.SEND" >
            <intent-filter>
                <action android:name="com.google.android.c2dm.intent.RECEIVE" />
                <category android:name="com.example.test_push_app" />
            </intent-filter>
        </receiver>
        <service android:name=".GcmMessageHandler" />

        <meta-data android:name="com.google.android.gms.version"
           android:value="@integer/google_play_services_version" />
    </application>

</manifest>

MainActivity.java我正在使用这个任务来注册

private class Register extends AsyncTask<Void, Void, String>{

        String regID;

        @Override
        protected String doInBackground(Void... params) {
            try{
                regID = gcm.register("40441*******");

            }catch(Exception ex){
                regID = "Failed";
                //Log.d("", ex.getMessage());
                ex.printStackTrace();
            }
            return regID;
        }
        @Override
        protected void onPostExecute(String result) {
            etRegid.setText(result);
            Log.d("", result);
            super.onPostExecute(result);
        }

    }

PhpResponse:

{
    "multicast_id": 7260653358308753695,
    "success": 1,
    "failure": 0,
    "canonical_ids": 0,
    "results": [{
        "message_id": "0:1422710889970517%ef663a58f9fd7ecd"
    }]
}

帮帮我!谢谢。

注意:GooglePlayServices 也安装在手机中。注册时我没有收到任何错误。

【问题讨论】:

  • 请发布整个日志 cat.and 在发送 gcm 时检查 php 脚本响应。
  • 日志猫没有什么可显示的。没有任何关系。并且 php 脚本没有响应。
  • @ImtiyazKhalani 查看上面的 php 响应
  • 你试过不同的设备吗?您可以查看here 以获得一些想法。

标签: android google-cloud-messaging android-broadcast


【解决方案1】:

确保你有

  1. 使用正确的密钥对构建进行签名(开发与生产)
  2. 更新了您的 php 脚本以将消息发送到新的 GCM 注册 ID

【讨论】:

  • 我处于调试模式。直接从eclipse安装到手机中。然后我正在注册应用程序并在php脚本中使用这个regID。脚本没有给出错误,但应用程序没有收到任何内容。我的互联网连接在手机上运行良好。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多