Excepción al abrir la notificación de inserción de Parse

Configuré Parse push Android SDK 1.7.0 y puedo recibir impulsos sin ningún problema. Sin embargo, al abrir la notificación de inserción, mi aplicación falla con la siguiente excepción:

android.content.ActivityNotFoundException: no se ha encontrado actividad para manejar el bash {act = android.intent.action.VIEW dat = flg = 0x1000c000 (tiene extras)}

También traté de subclasificar ParsePushBroadcastReceiver con getActivity() siempre devolviendo la clase de actividad principal, el mismo resultado. A continuación se muestra la stacktrace completa:

 E/AndroidRuntime﹕ FATAL EXCEPTION: main Process: com.ers.test, PID: 13513 java.lang.RuntimeException: Unable to start receiver com.ers.test.MyPushBroadcastReceiver: android.content.ActivityNotFoundException: No Activity found to handle Intent { act=android.intent.action.VIEW dat= flg=0x1000c000 (has extras) } at android.app.ActivityThread.handleReceiver(ActivityThread.java:2452) at android.app.ActivityThread.access$1700(ActivityThread.java:144) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1281) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:136) at android.app.ActivityThread.main(ActivityThread.java:5146) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:515) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:796) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:612) at dalvik.system.NativeStart.main(Native Method) Caused by: android.content.ActivityNotFoundException: No Activity found to handle Intent { act=android.intent.action.VIEW dat= flg=0x1000c000 (has extras) } at android.app.Instrumentation.checkStartActivityResult(Instrumentation.java:1632) at android.app.Instrumentation.execStartActivitiesAsUser(Instrumentation.java:1481) at android.app.ContextImpl.startActivitiesAsUser(ContextImpl.java:1136) at android.content.ContextWrapper.startActivitiesAsUser(ContextWrapper.java:344) at android.content.ContextWrapper.startActivitiesAsUser(ContextWrapper.java:344) at android.app.TaskStackBuilder.startActivities(TaskStackBuilder.java:221) at android.app.TaskStackBuilder.startActivities(TaskStackBuilder.java:232) at android.app.TaskStackBuilder.startActivities(TaskStackBuilder.java:208) at com.parse.TaskStackBuilderHelper.startActivities(TaskStackBuilderHelper.java:19) at com.parse.ParsePushBroadcastReceiver.onPushOpen(ParsePushBroadcastReceiver.java:202) at com.parse.ParsePushBroadcastReceiver.onReceive(ParsePushBroadcastReceiver.java:108) at android.app.ActivityThread.handleReceiver(ActivityThread.java:2445) at android.app.ActivityThread.access$1700(ActivityThread.java:144) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1281) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:136) at android.app.ActivityThread.main(ActivityThread.java:5146) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:515) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:796) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:612) at dalvik.system.NativeStart.main(Native Method) 

Después de pasar algunas horas. Encontré una solución: Implementa tu receptor y extiende la clase ParsePushBroadcastReceiver.

Receiver.java

 public class Receiver extends ParsePushBroadcastReceiver { @Override public void onPushOpen(Context context, Intent intent) { Log.e("Push", "Clicked"); Intent i = new Intent(context, HomeActivity.class); i.putExtras(intent.getExtras()); i.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); context.startActivity(i); } } 

Úselo en manifiesto, (en lugar de usar ParsePushBroadcastReceiver)

Código para el manifiesto del proyecto:

        

Happy Coding !!

La causa de esta excepción es cuando ParsePushBroadcastReceiver quiere abrir el uri vacío en su mensaje de inserción en este código:

 String uriString = null; try { JSONObject pushData = new JSONObject(intent.getStringExtra("com.parse.Data")); uriString = pushData.optString("uri"); } catch (JSONException e) { Parse.logE("com.parse.ParsePushReceiver", "Unexpected JSONException when receiving push data: ", e); } if (uriString != null) { activityIntent = new Intent("android.intent.action.VIEW", Uri.parse(uriString)); } else { activityIntent = new Intent(context, cls); } 

Si solo uriString un mensaje, el uriString estará vacío, no nulo, entonces context.startActivity(activityIntent); abrirá un uri vacío y se produce una excepción.

Para resolver este problema, puede subclasificar ParsePushBroadcastReceiver (gracias a @Ahmad Raza) y anular el dePushopen de la siguiente manera:

 public class Receiver extends ParsePushBroadcastReceiver { @Override protected void onPushOpen(Context context, Intent intent) { ParseAnalytics.trackAppOpenedInBackground(intent); String uriString = null; try { JSONObject pushData = new JSONObject(intent.getStringExtra("com.parse.Data")); uriString = pushData.optString("uri"); } catch (JSONException e) { Log.v("com.parse.ParsePushReceiver", "Unexpected JSONException when receiving push data: ", e); } Class cls = getActivity(context, intent); Intent activityIntent; if (uriString != null && !uriString.isEmpty()) { activityIntent = new Intent(Intent.ACTION_VIEW, Uri.parse(uriString)); } else { activityIntent = new Intent(context, MainActivity.class); } activityIntent.putExtras(intent.getExtras()); if (Build.VERSION.SDK_INT >= 16) { TaskStackBuilder stackBuilder = TaskStackBuilder.create(context); stackBuilder.addParentStack(cls); stackBuilder.addNextIntent(activityIntent); stackBuilder.startActivities(); } else { activityIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); activityIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); context.startActivity(activityIntent); } } } 

y actualiza Manifiesto como este:

        

Espero que resuelvan el problema en su próxima actualización.