2012-12-21 14 views
7

मैं अपने आवेदन में जीसीएम लागू कर रहा हूं। मैंने डेवलपर.android.comजीसीएम: GCMIntentService से मेमेज() को कई बार बुलाया जाता है?

से जीसीएम ट्यूटोरियल में दिए गए सभी चरणों का पालन किया है, मैं सफलतापूर्वक जीसीएम से पंजीकरण आईडी प्राप्त करने में सक्षम हूं, और मैं अपने आईडी सर्वर पर यह आईडी पास कर रहा हूं। तो पंजीकरण कदम सफलतापूर्वक किया जाता है।

अब अपने आवेदन सर्वर मेरे डिवाइस के लिए एक PUSH संदेश भेजता है, सर्वर संदेश सफलता = 8 विफलता = 0, आदि, यानी सर्वर संदेश दे रहा है सफलतापूर्वक, लेकिन OnMessage 8 बार पर निर्भर करता है कहा जाता हो रही है के रूप में हो जाता है सफलता मूल्य।

मेरा डिवाइस किसी भी प्रॉक्सी सेटिंग्स के बिना मेरे संगठन वाईफ़ाई को फेंक दिया।

तो मेरा सवाल है: मुझे सफलता मूल्य के जितना समय जीसीएम से पुश संदेश प्राप्त हो रहा है। Google इतना समय क्यों दे रहा है? क्या कारण हो सकता है?

मेरे GCMBaseIntentService लग रहा है

तरह
public class GCMIntentService extends GCMBaseIntentService { 




    public GCMIntentService() { 
     super(GCMActivity.SENDER_ID); 
    } 

    @Override 
    protected void onError(Context arg0, String arg1) { 

     Log.d("GCM", "RECIEVED A ERROR MESSAGE"); 
     // TODO Auto-generated method stub 

    } 

    @Override 
    protected void onRegistered(Context arg0, String registrationId) { 

//Send the registration id to my app server to store the reg id list 
     GCMActivity.sendRegIdtoApplicationServer(registrationId); 

    } 


    @Override 
    protected void onUnregistered(Context arg0, String registrationId) { 
     // TODO Auto-generated method stub 

    } 

    @Override 
    protected void onMessage(Context context, Intent intent) { 
     Log.d("GCM", "RECIEVED A MESSAGE"); 

     // Get the data from intent and send to notificaion bar 


     String data = intent.getStringExtra("data"); 
     String action = intent.getAction(); 

     if((action.equals("com.google.android.c2dm.intent.RECEIVE"))) { 
      try { 
       JSONObject jsonObject = new JSONObject(data); 
       boolean updateStatus = jsonObject.getBoolean("update"); 



       if (updateStatus) { 
        //Showing Notification to user 


       } 

      } catch (JSONException e) { 
       // TODO Auto-generated catch block 
       e.printStackTrace(); 
      } 
     } 



    } 

मेरी गतिविधि लग रहा है

तरह
public class GCMActivity extends Activity { 

    public final static String SENDER_ID = "872355133485"; 

    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_gcm); 

     GCMRegistrar.checkDevice(this); 
     GCMRegistrar.checkManifest(this); 
     final String regId = GCMRegistrar.getRegistrationId(this); 
     if (regId.equals("")) { 
      GCMRegistrar.register(this, SENDER_ID); 

     } else { 

//   sendRegIdtoApplicationServer(regId); 
      Log.v("gh", "Already registered"); 
      System.out.println("RegisterID:"+ regId); 
      } 
     } 



And Manifest file will be 

<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
    package="com.aspire.gcmsample" 
    android:versionCode="1" 
    android:versionName="1.0" > 

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

    <permission android:name="com.aspire.gcmsample.permission.C2D_MESSAGE" android:protectionLevel="signature" /> 

    <uses-permission android:name="com.aspire.gcmsample.permission.C2D_MESSAGE" /> 
    <!-- App receives GCM messages. --> 
    <uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" /> 
    <!-- GCM connects to Google 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" /> 
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> 

    <application 
     android:icon="@drawable/ic_launcher" 
     android:label="@string/app_name" 
     android:theme="@style/AppTheme" android:debuggable="true"> 

     <activity 
      android:name=".GCMActivity" 
      android:label="@string/title_activity_gcm" > 
      <intent-filter> 
       <action android:name="android.intent.action.MAIN" /> 

       <category android:name="android.intent.category.LAUNCHER" /> 
      </intent-filter> 
     </activity> 

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

        <action android:name="com.google.android.c2dm.intent.REGISTRATION" /> 

        <category android:name="com.aspire.gcmsample" /> 

       </intent-filter> 
     </receiver> 

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


</manifest> 

यहाँ मेरी सर्वर साइड कोड

 Properties apHeaders = new Properties(); 

     // Use your own credentials for the below three lines 
     apHeaders.put("Content-Type", "application/json"); 
     apHeaders.put("Authorization","key="+apiKey); 

     /*String data = "{\"registration_ids\":"+ devicesList +", \"data\":" + 
       "{\"data\":{\"score\" : \"1-0\", \"scorer\" : \"Ronaldo\", \"time\" : \"44\"}}}";*/ 

     // get all registration Device ID from database 
     ArrayList<String> deviceId = DBRegistration.getInstance().fetchRegId(); 

     String data = "{\"registration_ids\":"+ deviceId +", \"data\":" + 
      "{\"data\":{\"update\" : \"true\", " + 
      "\"file\": \"http://192.168.4.210:8080/FileDownload/DownloadFile?path=GCMSample.apk\"}}}"; 

     String result = DBRegistration.getInstance().sendRequest(url, data, apHeaders);** 

     System.out.println("responseC"+ result); 
     out.println(result); 
     out.flush(); 

स्ट्रिंग apServerUrl = "https: // एंड्रॉयड। googleapis.com/gcm/send ";

public String sendRequest(String apServerUrl, String payload, Properties headers) { 

     // Setup Http URL connection 

     HttpURLConnection connection = null; 

     // Enable proxy if it needed. 
     Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress(PROXY_URL, PROXY_PORT)); 

     try { 
      URL url = new URL(apServerUrl); 
      // Enable proxy if needed. 
      connection = (HttpURLConnection) url.openConnection(proxy); 
      //connection = (HttpURLConnection) url.openConnection(); 
      connection.setRequestMethod("POST"); 
      connection.setDoOutput(true); 
      Object[] keys = headers.keySet().toArray(); 
      for (int i = 0; i < keys.length; i++) { 
       connection.setRequestProperty((String) keys[i], 
         (String) headers.get(keys[i])); 
      } 
      //connection.setRequestProperty("Content-Length", ""+ payload.length()); 
     } catch (Exception e) { 
      System.out.println("Failed setting up HTTP Connection\n" + e); 
     } 

     // Send the Request 
     String line = ""; 
     String returnedResponse = ""; 
     BufferedReader reader = null; 

     System.out.println("Request: " + payload); 

     try { 
      OutputStream os = connection.getOutputStream(); 
      os.write(payload.toString().getBytes("UTF-8")); 
      os.close(); 
      int status = connection.getResponseCode();    
      if (status != 200) { 
       System.out.println("HTTP Error code " + status 
         + " received, transaction not submitted"); 
       reader = new BufferedReader(new InputStreamReader(connection 
         .getErrorStream())); 
      } else { 
       reader = new BufferedReader(new InputStreamReader(connection 
         .getInputStream())); 
      } 

      while ((line = reader.readLine()) != null) { 
       returnedResponse += line; 
      } 
     } catch (Exception e) { 
      returnedResponse = e.getMessage(); 
      System.out.println(e); 
     } finally { 
      try { 
       if (reader != null) 
        reader.close(); 
       if (connection != null) 
        connection.disconnect(); 
      } catch (Exception e) { 
       returnedResponse = e.getMessage(); 
       System.out.println(e); 
      } 
     } 
     System.out.println(returnedResponse); 
     return returnedResponse; 
    } 

जीसीएम सर्वर से मेरे ऐप सर्वर पर प्रतिक्रिया।

{"multicast_id":6552291927399218343,"success":13,"failure":0,"canonical_ids":0,"results":[{"message_id":"0:1356332586480671%79fa3a68f9fd7ecd"},{"message_id":"0:1356332586480674%79fa3a68f9fd7ecd"},{"message_id":"0:1356332586481759%79fa3a68f9fd7ecd"},{"message_id":"0:1356332586480807%79fa3a68f9fd7ecd"},{"message_id":"0:1356332586481944%79fa3a68f9fd7ecd"},{"message_id":"0:1356332586480996%79fa3a68f9fd7ecd"},{"message_id":"0:1356332586481939%79fa3a68f9fd7ecd"},{"message_id":"0:1356332586482000%79fa3a68f9fd7ecd"},{"message_id":"0:1356332586481997%79fa3a68f9fd7ecd"},{"message_id":"0:1356332586481942%79fa3a68f9fd7ecd"},{"message_id":"0:1356332586482003%79fa3a68f9fd7ecd"},{"message_id":"0:1356332586481948%79fa3a68f9fd7ecd"},{"message_id":"0:1356332586480995%79fa3a68f9fd7ecd"}]} 
+0

मेरे जीसीएम ऐप्स में यह ऐसा नहीं कर रहा है - अगर आप मुझसे पूछें तो क्या आपके कोड में एक बग की तरह लगता है - क्या आप कोड दिखा सकते हैं? – ligi

+0

@ ligi मैंने अपना कोड जोड़ा। – Lakshmanan

+1

सर्वर साइड कोड कहां है जहां आप विशेष पंजीकरण आईडी के साथ संदेश भेजते हैं? – appukrb

उत्तर

5

जीसीएम से आपके सर्वर को आपकी प्रतिक्रिया क्या दिखाई देती है? यह संभव है कि आपके पास एक ही डिवाइस अलग-अलग आईडी के साथ 8 अलग-अलग समय पंजीकृत हो, जो मुझे सबसे अधिक संभावित कारण लगता है।

आपको यह भी सुनिश्चित करना होगा कि आप जीसीएम सर्वर पर भेज रहे कोड को देखना चाहिए ताकि आप एक ही पंजीकरण आईडी आठ बार नहीं भेज रहे हैं।

प्रतिक्रिया स्वरूप यहाँ प्रलेखित है: https://developer.android.com/google/gcm/gcm.html#response

उस आधार पर मैं एक बार देख ले और देखो अगर आप किसी भी विहित ईद की है, जो आप को दिखाने के लिए आप एक ही डिवाइस कई बार पंजीकृत है कि मदद मिलेगी प्राप्त कर रहे हैं होगा। आप कैनोनिकल आईडी के साथ क्या करना है इसके बारे में अधिक पढ़ सकते हैं: android GCM get original id of canonical id

+0

@ सेल्सिन जोड़ा; मैंने जीसीएम सर्वर प्रतिक्रिया जोड़ा है। कृपया इसे कॉनोनिकल आईडी देखें 0. – Lakshmanan

+0

धन्यवाद सेल्सिन: मुझे समस्या पता है।मेरे सर्वर साइड कोड के साथ समस्या, जैसे कि आपकी धारणा एकल पंजीकरण आईडी ने मेरे पेलोड डेटा की डिवाइस सूची में कई बार जोड़ा। – Lakshmanan

0

प्रलेखन http://developer.android.com/google/gcm/gcm.html#response पर, success संदेश जो एक त्रुटि के बिना प्रोसेस किया गया की संख्या है। शायद इस मामले में, जीसीएम एक ही आईडी में 8 बार संदेश भेजता है।

संबंधित मुद्दे