Hello Friends,
Here i will show code for client side android.
Manifest file
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="in.blogspot.longjamcode"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="14"
android:targetSdkVersion="19" />
<--give all these uses-permission-->
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="android.permission.WAKE_LOCK" />
<permission
android:name="in.blogspot.longjamcode.permission.C2D_MESSAGE"
android:protectionLevel="signature" />
<uses-permission android:name="com.example.gcmdemo.permission.C2D_MESSAGE" />
<uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.VIBRATE" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<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>
<--here is Receiver-->
<receiver
android:name=".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="in.blogspot.longjamcode" />
</intent-filter>
</receiver>
</application>
</manifest>
Simple Layout file
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/LinearLayout1"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:gravity="center"
tools:context="in.blogspot.longjamcode.MainActivity" >
<--This button is for Registering with cloud server-->
<Button
android:id="@+id/registerButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Register with cloud server" />
<--This button is to share RegisterId with App server-->
<Button
android:id="@+id/sendButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="50dp"
android:text="Share register id with app server" />
</LinearLayout>
Following is MainActivity.java file
package in.blogspot.longjamcode;
import java.util.ArrayList;
import java.util.List;
import javax.net.ssl.SSLPeerUnverifiedException;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.util.EntityUtils;
import android.app.Activity;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.AsyncTask;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.Toast;
public class MainActivity extends Activity {
private final String PROJECT_NUMBER = "YOUR PROJECT NUMBER";
private Button registerButton, sendButton;
private SharedPreferences preferences;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
registerButton = (Button) findViewById(R.id.registerButton);
sendButton = (Button) findViewById(R.id.sendButton);
preferences = getSharedPreferences("gcm", Context.MODE_PRIVATE);
registerButton.setOnClickListener(register);
sendButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
MyAsynClass asynClass = new MyAsynClass();
asynClass.execute("http://YOUR IP ADDRESS:8080/GCMServer/RegisterServlet");
}
});
}
OnClickListener register = new OnClickListener() {
@Override
public void onClick(View v) {
//Getting gcm_id from preference and check it whether it exist or not if not call registerWithCloudServer() method
if(preferences.getString("gcm_id", "").length() == 0) {
registerWithCloudServer();
}
else {
Toast.makeText(MainActivity.this, "Already Register", Toast.LENGTH_SHORT).show();
}
}
};
//Method to register with cloud server
public void registerWithCloudServer(){
Intent registrationIntent=new Intent("com.google.android.c2dm.intent.REGISTER");
registrationIntent.putExtra("app", PendingIntent.getBroadcast(this, 0, new Intent(), 0));
registrationIntent.putExtra("sender", PROJECT_NUMBER);
startService(registrationIntent);
}
private class MyAsynClass extends AsyncTask<String, String, String> {
@Override
protected String doInBackground(String... params) {
HttpPost httpPost= new HttpPost(params[0]);
DefaultHttpClient client = new DefaultHttpClient();
try {
List<NameValuePair> list = new ArrayList<NameValuePair>();
list.add(new BasicNameValuePair("gcm_id", preferences.getString("gcm_id", "")));
httpPost.setEntity(new UrlEncodedFormEntity(list));
HttpResponse response = client.execute(httpPost);
HttpEntity entity = response.getEntity();
String responseText = EntityUtils.toString(entity);
return responseText;
}catch (SSLPeerUnverifiedException e) {
e.printStackTrace();
return null;
}catch (Exception e) {
e.printStackTrace();
return null;
}
}
}
}
Here i will show code for client side android.
Manifest file
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="in.blogspot.longjamcode"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="14"
android:targetSdkVersion="19" />
<--give all these uses-permission-->
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="android.permission.WAKE_LOCK" />
<permission
android:name="in.blogspot.longjamcode.permission.C2D_MESSAGE"
android:protectionLevel="signature" />
<uses-permission android:name="com.example.gcmdemo.permission.C2D_MESSAGE" />
<uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.VIBRATE" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<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>
<--here is Receiver-->
<receiver
android:name=".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="in.blogspot.longjamcode" />
</intent-filter>
</receiver>
</application>
</manifest>
Simple Layout file
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/LinearLayout1"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:gravity="center"
tools:context="in.blogspot.longjamcode.MainActivity" >
<--This button is for Registering with cloud server-->
<Button
android:id="@+id/registerButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Register with cloud server" />
<--This button is to share RegisterId with App server-->
<Button
android:id="@+id/sendButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="50dp"
android:text="Share register id with app server" />
</LinearLayout>
Following is MainActivity.java file
package in.blogspot.longjamcode;
import java.util.ArrayList;
import java.util.List;
import javax.net.ssl.SSLPeerUnverifiedException;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.util.EntityUtils;
import android.app.Activity;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.AsyncTask;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.Toast;
public class MainActivity extends Activity {
private final String PROJECT_NUMBER = "YOUR PROJECT NUMBER";
private Button registerButton, sendButton;
private SharedPreferences preferences;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
registerButton = (Button) findViewById(R.id.registerButton);
sendButton = (Button) findViewById(R.id.sendButton);
preferences = getSharedPreferences("gcm", Context.MODE_PRIVATE);
registerButton.setOnClickListener(register);
sendButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
MyAsynClass asynClass = new MyAsynClass();
asynClass.execute("http://YOUR IP ADDRESS:8080/GCMServer/RegisterServlet");
}
});
}
OnClickListener register = new OnClickListener() {
@Override
public void onClick(View v) {
//Getting gcm_id from preference and check it whether it exist or not if not call registerWithCloudServer() method
if(preferences.getString("gcm_id", "").length() == 0) {
registerWithCloudServer();
}
else {
Toast.makeText(MainActivity.this, "Already Register", Toast.LENGTH_SHORT).show();
}
}
};
//Method to register with cloud server
public void registerWithCloudServer(){
Intent registrationIntent=new Intent("com.google.android.c2dm.intent.REGISTER");
registrationIntent.putExtra("app", PendingIntent.getBroadcast(this, 0, new Intent(), 0));
registrationIntent.putExtra("sender", PROJECT_NUMBER);
startService(registrationIntent);
}
private class MyAsynClass extends AsyncTask<String, String, String> {
@Override
protected String doInBackground(String... params) {
HttpPost httpPost= new HttpPost(params[0]);
DefaultHttpClient client = new DefaultHttpClient();
try {
List<NameValuePair> list = new ArrayList<NameValuePair>();
list.add(new BasicNameValuePair("gcm_id", preferences.getString("gcm_id", "")));
httpPost.setEntity(new UrlEncodedFormEntity(list));
HttpResponse response = client.execute(httpPost);
HttpEntity entity = response.getEntity();
String responseText = EntityUtils.toString(entity);
return responseText;
}catch (SSLPeerUnverifiedException e) {
e.printStackTrace();
return null;
}catch (Exception e) {
e.printStackTrace();
return null;
}
}
}
}
Following is receiver....
package in.blogspot.longjamcode;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.media.RingtoneManager;
import android.net.Uri;
import android.support.v4.content.WakefulBroadcastReceiver;
import android.widget.Toast;
public class GCMBroadcastReceiver extends WakefulBroadcastReceiver{
@Override
public void onReceive(Context context, Intent intent) {
String action=intent.getAction();
if(action.equalsIgnoreCase("com.google.android.c2dm.intent.REGISTRATION")){
onRegistration(context,intent);
}else if(action.equalsIgnoreCase("com.google.android.c2dm.intent.RECEIVE")){
NotificationManager notificationManager = (NotificationManager)
context.getSystemService(context.NOTIFICATION_SERVICE);
PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, new Intent(), Intent.FLAG_ACTIVITY_NEW_TASK);
Notification notify=new Notification(R.drawable.ic_launcher,"icon",System.currentTimeMillis());
Uri alarmSound = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
if(alarmSound!=null)
notify.sound = alarmSound;
notify.setLatestEventInfo(context, "Notification", intent.getExtras().getString("message"), pendingIntent);
notificationManager.notify(0, notify);
}
}
public void onRegistration(Context context,Intent intent){
String registrationID=intent.getStringExtra("registration_id");
if(registrationID!=null){
SharedPreferences preferences = context.getSharedPreferences("gcm", Context.MODE_PRIVATE);
SharedPreferences.Editor editor = preferences.edit();
editor.putString("gcm_id",registrationID);
editor.commit();
Toast.makeText(context, ""+registrationID, Toast.LENGTH_SHORT).show();
}else
Toast.makeText(context, "error in registration" , Toast.LENGTH_LONG).show();
}
}
And don't to add google-play-services-lib to your project
And don't to add google-play-services-lib to your project
No comments:
Post a Comment