0

我想实现一个android应用程序的通知服务器。我遵循教程http://javapapers.com/android/google-cloud-messaging-gcm-for-android-and-push-notifications/和它的工作正常。但是现在,服务器端的所有内容都由我的通知服务器处理,我通过它与用户登录时共享我的设备ID和userId。我的通知服务器成功将regid发送到gcm,但我没有收到我设备上的通知。我的onReceive()现在没有被调用。这是我的服务器从gcm收到的响应。 MESSAGEID = 0:1463550332634647%fd0791fdf9fd7ecdNot received从通知服务器发送的GCM通知

Config.java

public interface Config { 

//static final String APP_SERVER_URL = "http://192.168.100.27:8081/GCMServer/GCMNotification?shareRegId=1";//earlier it was used to share regid with server 
static final String GOOGLE_PROJECT_ID = "299876636766"; 
static final String MESSAGE_KEY = "message"; 

} 

GCMNotificationIntentService.java

public class GCMNotificationIntentService extends IntentService { 

public static final int NOTIFICATION_ID = 1; 
private NotificationManager mNotificationManager; 
NotificationCompat.Builder builder; 

public GCMNotificationIntentService() { 
    super("GcmIntentService"); 
} 

public static final String TAG = "GCMNotificationIntentService"; 

@Override 
protected void onHandleIntent(Intent intent) { 
    Bundle extras = intent.getExtras(); 
    GoogleCloudMessaging gcm = GoogleCloudMessaging.getInstance(this); 

    String messageType = gcm.getMessageType(intent); 
    System.out.println("MessageType is"+messageType); 
    String msg = intent.getStringExtra("message"); 
    System.out.println("mESSAGE IS---->>>"+msg); 

    if (!extras.isEmpty()) { 
     if (GoogleCloudMessaging.MESSAGE_TYPE_SEND_ERROR 
       .equals(messageType)) { 
      sendNotification("Send error: " + extras.toString()); 
     } else if (GoogleCloudMessaging.MESSAGE_TYPE_DELETED 
       .equals(messageType)) { 
      sendNotification("Deleted messages on server: " 
        + extras.toString()); 
     } else if (GoogleCloudMessaging.MESSAGE_TYPE_MESSAGE 
       .equals(messageType)) { 

      for (int i = 0; i < 3; i++) { 
       Log.i(TAG, 
         "Working... " + (i + 1) + "/5 @ " 
           + SystemClock.elapsedRealtime()); 
       try { 
        Thread.sleep(5000); 
       } catch (InterruptedException e) { 
       } 

      } 
      Log.i(TAG, "Completed work @ " + SystemClock.elapsedRealtime()); 

      sendNotification(""+msg); 
      Log.i(TAG, "Received: " + extras.toString()); 
     } 
    } 
    GcmBroadcastReceiver.completeWakefulIntent(intent); 
} 

private void sendNotification(String msg) { 
    Log.d(TAG, "Preparing to send notification...: " + msg); 
    System.out.println("Message is"+msg); 
    mNotificationManager = (NotificationManager) this 
      .getSystemService(Context.NOTIFICATION_SERVICE); 
    PendingIntent contentIntent=null ; 
    if(msg.equalsIgnoreCase("call")){ 
     System.out.println("Inside iffffffffffffffffffffff"); 
     PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE); 

     PowerManager.WakeLock wl = pm.newWakeLock(PowerManager.ACQUIRE_CAUSES_WAKEUP, "tag"); 
     wl.acquire(); 
     Intent i = new Intent(getApplicationContext(), MainActivity.class); 
     i.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); 
     startActivity(i); 
     //setResultCode(Activity.RESULT_OK) 

     wl.release(); 
     contentIntent = PendingIntent.getActivity(this, 0, 
       new Intent(this, SplashScreen.class), 0); 
     System.out.println("the content intent is"+contentIntent.toString()); 

    }else{ 
     System.out.println("Inside else"); 
     contentIntent = PendingIntent.getActivity(this, 0, 
       new Intent(this, MainActivity.class), 0); 


    } 
    NotificationCompat.Builder mBuilder = new NotificationCompat.Builder(
      this).setSmallIcon(R.drawable.ic_launcher) 
      .setContentTitle("GCM Notification") 
      .setStyle(new NotificationCompat.BigTextStyle().bigText(msg)) 
      .setContentText(msg); 

    mBuilder.setContentIntent(contentIntent); 
    mNotificationManager.notify(NOTIFICATION_ID, mBuilder.build()); 

    Log.d(TAG, "Notification sent successfully."); 
} 
} 

GCMBroadcastReceiver.java

public class GcmBroadcastReceiver extends WakefulBroadcastReceiver { 

@Override 
public void onReceive(Context context, Intent intent) { 
    ComponentName comp = new ComponentName(context.getPackageName(), 
      GCMNotificationIntentService.class.getName()); 
    startWakefulService(context, (intent.setComponent(comp))); 
    setResultCode(Activity.RESULT_OK); 
} 
} 
+0

你有没有得到任何错误日志?并让你在php文件中更改密钥? –

+0

GCM服务器的回应是什么? –

+0

@NiranjPatel messageId(长字符串)和规范注册编号 – SwagDevelopers

回答

1

如果从获得成功的消息像下面GCM服务器,那么你的设备必须收到通知

成功消息从GCM服务器

{ 
    "multicast_id": 661164****4469281, 
    "success": 1, 
    "failure": 0, 
    "canonical_ids": 1, 
    "results": [{ 
     "registration_id": "APA91bFWKKC4Bh_B******-H", 
     "message_id": "0:14635506***b6f9fd7ecd" 
    }] 
} 

可低于对于在设备未接收到的消息的情况。

  1. 在android侧的错误发件人ID。
  2. 服务器端(PHP)错误的Google API密钥。
  3. 错误的设备注册ID您要发送到GCM服务器。

请立即验证所有值并检查。 如果一切都很完美,那么你必须在设备中收到消息。 请检查您的设备中的互联网连接。

请验证您的Menifest.xml文件以下。

<receiver 
      android:name=".GCMBroadcastReceiver" 
      android:permission="com.google.android.c2dm.permission.SEND" > 
      <intent-filter> 

       <!-- Receives the actual messages. --> 
       <action android:name="com.google.android.c2dm.intent.RECEIVE" /> 
       <!-- Receives the registration id. --> 
       <action android:name="com.google.android.c2dm.intent.REGISTRATION" /> 

       <category android:name="your_package" /> 
      </intent-filter> 
     </receiver> 

     <service android:name=".GCMIntentService" /> 
    </application> 

    <!-- GCM connects to Internet Services. --> 
    <uses-permission android:name="android.permission.INTERNET" /> 

    <!-- GCM requires a Google account. --> 
    <uses-permission android:name="android.permission.GET_ACCOUNTS" /> 

    <!-- Keeps the processor from sleeping when a message is received. --> 
    <uses-permission android:name="android.permission.WAKE_LOCK" /> 

    <!-- Creates a custom permission so only this app can receive its messages. --> 
    <permission 
     android:name="your_package.permission.C2D_MESSAGE" 
     android:protectionLevel="signature" /> 

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

    <!-- This app has permission to register and receive data message. --> 
    <uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" /> 

    <!-- Network State Permissions to detect Internet status --> 
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> 
+0

我发送电子邮件regId从regId = gcm.register()接收邮件。 Api键也是正确的。请检查两次。 – SwagDevelopers

+0

我看到这篇文章http://stackoverflow.com/questions/21515141/broadcastreceiver-is-never-called-using-gcm-service好像有类似的问题,但解决方案和理由我不明白。 – SwagDevelopers