サーバーからプッシュされたアラートを受信するアプリを書きたいと思っています。これを行う方法がいくつか見つかりました。
- SMS-着信SMSをインターセプトし、サーバーからのプルを開始します
- サーバーを定期的にポーリングする
それぞれに独自の制限があります。SMS-到着時間の保証はありません。投票によりバッテリーが消耗する可能性があります。
もっと良い提案がありますか?どうもありがとう。
サーバーからプッシュされたアラートを受信するアプリを書きたいと思っています。これを行う方法がいくつか見つかりました。
それぞれに独自の制限があります。SMS-到着時間の保証はありません。投票によりバッテリーが消耗する可能性があります。
もっと良い提案がありますか?どうもありがとう。
回答:
Googleの公式回答はAndroid Cloud to Device Messaging Framework(非推奨) Google Cloud Messaging(非推奨) Firebase Cloud Messagingです
Android 2.2以上で動作します(Playストアのあるスマートフォン)。
(私が同様の質問に与えた回答からのクロス投稿-Androidはほぼリアルタイムのプッシュ通知をサポートしていますか?)
私は最近、この種のことを行う方法として、Android向けのMQTT http://mqtt.org(つまり、SMSではなくデータ主導のプッシュ通知、ほぼ即時のメッセージ配信、ポーリングではないなど)を試し始めました。
役立つ場合に備えて、これに関する背景情報をブログに投稿しています
http://dalelane.co.uk/blog/?p=938
(注:MQTTはIBMテクノロジーであり、私がIBMで働いていることを指摘しておきます。)
Androidプッシュ通知に関する私の理解/経験は次のとおりです。
C2DM GCMは -あなたのターゲットAndroidプラットフォームが2.2以降であれば、それのために行きます。たった1つのキャッチとして、デバイスユーザーはメッセージを取得するために常に Googleアカウントでログインする必要があります。
MQTT -Pub / Subベースのアプローチ。デバイスからのアクティブな接続が必要です。適切に実装されていないと、バッテリーを消耗する可能性があります。
執事 -コミュニティのサポートが限られているため、長期的にはうまくいかない可能性があります。
編集:2013年11月25日に追加
GCM-グーグルは言う...
3.0より前のデバイスの場合、ユーザーはモバイルデバイスでGoogleアカウントをセットアップする必要があります。Android 4.0.4以降を実行しているデバイスでは、Googleアカウントは必須ではありません。*
Android Cloud to Deviceメッセージングフレームワーク
重要:C2DMは、2012年6月26日をもって正式に廃止されました。をもってこれは、C2DMが新しいユーザーと割り当てリクエストの受け入れを停止したことを意味します。C2DMに新機能は追加されません。ただし、C2DMを使用するアプリは引き続き機能します。既存のC2DM開発者は、Google Cloud Messaging for Android(GCM)と呼ばれる新しいバージョンのC2DMに移行することをお勧めします。詳細については、C2DMからGCMへの移行に関するドキュメントをご覧ください。開発者は新しい開発にGCMを使用する必要があります。
以下のリンクをご確認ください。
ここでは、最初からRegIDと通知を取得する方法についていくつかの手順を説明しました
以下のURLリンクで完全なチュートリアルを見つけることができます
Androidプッシュ通知の開始:最新のGoogleクラウドメッセージング(GCM)-ステップバイステップの完全なチュートリアル
登録ID(プッシュ通知のデバイストークン)を取得するコードスニップ。
GCMのプロジェクトを構成する
プロジェクトでGCMを有効にするには、マニフェストファイルにいくつかの権限を追加する必要があります。AndroidManifest.xmlに移動し、以下のコードを追加します。権限の追加
<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="android.permission.VIBRATE" />
<uses-permission android:name=“.permission.RECEIVE" />
<uses-permission android:name=“<your_package_name_here>.permission.C2D_MESSAGE" />
<permission android:name=“<your_package_name_here>.permission.C2D_MESSAGE"
android:protectionLevel="signature" />
GCMブロードキャストレシーバー宣言を追加
アプリケーションタグにGCMブロードキャストレシーバー宣言を追加する
<application
<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="" />
</intent-filter]]>
</receiver]]>
<application/>
GCM Servie宣言を追加
<application
<service android:name=".GcmIntentService" />
<application/>
次に、起動/スプラッシュアクティビティに移動します
定数とクラス変数を追加する
private final static int PLAY_SERVICES_RESOLUTION_REQUEST = 9000;
public static final String EXTRA_MESSAGE = "message";
public static final String PROPERTY_REG_ID = "registration_id";
private static final String PROPERTY_APP_VERSION = "appVersion";
private final static String TAG = "LaunchActivity";
protected String SENDER_ID = "Your_sender_id";
private GoogleCloudMessaging gcm =null;
private String regid = null;
private Context context= null;
OnCreateメソッドとOnResumeメソッドを更新する
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_launch);
context = getApplicationContext();
if (checkPlayServices())
{
gcm = GoogleCloudMessaging.getInstance(this);
regid = getRegistrationId(context);
if (regid.isEmpty())
{
registerInBackground();
}
else
{
Log.d(TAG, "No valid Google Play Services APK found.");
}
}
}
@Override protected void onResume()
{
super.onResume(); checkPlayServices();
}
# Implement GCM Required methods (Add below methods in LaunchActivity)
private boolean checkPlayServices() {
int resultCode = GooglePlayServicesUtil.isGooglePlayServicesAvailable(this);
if (resultCode != ConnectionResult.SUCCESS) {
if (GooglePlayServicesUtil.isUserRecoverableError(resultCode)) {
GooglePlayServicesUtil.getErrorDialog(resultCode, this,
PLAY_SERVICES_RESOLUTION_REQUEST).show();
} else {
Log.d(TAG, "This device is not supported - Google Play Services.");
finish();
}
return false;
}
return true;
}
private String getRegistrationId(Context context)
{
final SharedPreferences prefs = getGCMPreferences(context);
String registrationId = prefs.getString(PROPERTY_REG_ID, "");
if (registrationId.isEmpty()) {
Log.d(TAG, "Registration ID not found.");
return "";
}
int registeredVersion = prefs.getInt(PROPERTY_APP_VERSION, Integer.MIN_VALUE);
int currentVersion = getAppVersion(context);
if (registeredVersion != currentVersion) {
Log.d(TAG, "App version changed.");
return "";
}
return registrationId;
}
private SharedPreferences getGCMPreferences(Context context)
{
return getSharedPreferences(LaunchActivity.class.getSimpleName(),
Context.MODE_PRIVATE);
}
private static int getAppVersion(Context context)
{
try
{
PackageInfo packageInfo = context.getPackageManager()
.getPackageInfo(context.getPackageName(), 0);
return packageInfo.versionCode;
}
catch (NameNotFoundException e)
{
throw new RuntimeException("Could not get package name: " + e);
}
}
private void registerInBackground()
{ new AsyncTask() {
Override
protected Object doInBackground(Object... params)
{
String msg = "";
try
{
if (gcm == null)
{
gcm = GoogleCloudMessaging.getInstance(context);
}
regid = gcm.register(SENDER_ID); Log.d(TAG, "########################################");
Log.d(TAG, "Current Device's Registration ID is: "+msg);
}
catch (IOException ex)
{
msg = "Error :" + ex.getMessage();
}
return null;
} protected void onPostExecute(Object result)
{ //to do here };
}.execute(null, null, null);
}
注意:REGISTRATION_KEYを保存してください。PNメッセージをGCMに送信することは重要です。これは、GCMがプッシュ通知を送信するだけで、すべてのデバイスで一意になることにください。
GCMブロードキャストレシーバークラスを追加
マニフェストファイルで「GcmBroadcastReceiver.java」をすでに宣言しているので、このクラスを作成して、この方法でレシーバークラスコードを更新します。
public class GcmBroadcastReceiver extends WakefulBroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent)
{ ComponentName comp = new ComponentName(context.getPackageName(),
GcmIntentService.class.getName()); startWakefulService(context, (intent.setComponent(comp)));
setResultCode(Activity.RESULT_OK);
Toast.makeText(context, “wow!! received new push notification", Toast.LENGTH_LONG).show();
}
}
GCMサービスクラスを追加
マニフェストファイルで「GcmBroadcastReceiver.java」をすでに宣言しているので、このクラスを作成して、この方法でレシーバークラスコードを更新します。
public class GcmIntentService extends IntentService
{ public static final int NOTIFICATION_ID = 1; private NotificationManager mNotificationManager; private final static String TAG = "GcmIntentService"; public GcmIntentService() {
super("GcmIntentService");
} @Override
protected void onHandleIntent(Intent intent) {
Bundle extras = intent.getExtras();
Log.d(TAG, "Notification Data Json :" + extras.getString("message"));
GoogleCloudMessaging gcm = GoogleCloudMessaging.getInstance(this);
String messageType = gcm.getMessageType(intent); 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()); // If it's a regular GCM message, do some work.
} else if (GoogleCloudMessaging.MESSAGE_TYPE_MESSAGE
.equals(messageType)) {
// This loop represents the service doing some work.
for (int i = 0; i < 5; i++) {
Log.d(TAG," Working... " + (i + 1) + "/5 @ "
+ SystemClock.elapsedRealtime()); try {
Thread.sleep(5000);
} catch (InterruptedException e) {
}
}
Log.i(TAG, "Completed work @ " + SystemClock.elapsedRealtime());
sendNotification(extras.getString("message"));
}
} // Release the wake lock provided by the WakefulBroadcastReceiver.
GcmBroadcastReceiver.completeWakefulIntent(intent);
} // Put the message into a notification and post it.
// This is just one simple example of what you might choose to do with
// a GCM message.
private void sendNotification(String msg) { mNotificationManager = (NotificationManager) this
.getSystemService(Context.NOTIFICATION_SERVICE);
PendingIntent contentIntent = PendingIntent.getActivity(this, 0, new Intent(this, LaunchActivity.class), 0);
NotificationCompat.Builder mBuilder = new NotificationCompat.Builder( this)
.setSmallIcon(R.drawable.icon)
.setContentTitle("Ocutag Snap")
.setStyle(new NotificationCompat.BigTextStyle().bigText(msg))
.setContentText(msg)
.setDefaults(Notification.DEFAULT_SOUND | Notification.DEFAULT_VIBRATE);
mBuilder.setContentIntent(contentIntent); mNotificationManager.notify(NOTIFICATION_ID, mBuilder.build());
}
}
Meteor Webサーバーに基づいて、Androidでプッシュ通知用のJavaライブラリを開発する新しいオープンソースの取り組みがあります。あなたはでそれをチェックアウトすることができディーコンプロジェクトブログあなたは流星へのリンクや、プロジェクトのGitHubのリポジトリを見つけることができます。開発者が必要なので広めてください!
Xtify(http://developer.xtify.com)を使用できます-彼らは彼らのSDKで動作するプッシュ通知ウェブサービスを持っています。それは無料で、今のところ、私にとっては非常にうまく機能しています。
または...
3)サーバーへの接続を維持し、数分ごとにキープアライブを送信すると、サーバーは即座にメッセージをプッシュできます。これがGmailやGoogleトークなどの仕組みです。
GCMを使用することをお勧めします-Android向けGoogleクラウドメッセージングは 無料で、簡単に使用するには非常に簡単です。
ただし、ユーザーに代わって通知を送信するには、サードサイドサーバーを維持する必要があります。あなたがそれを避けたいなら、Androidのプッシュ通知サービスのためのいくつかの非常に優れた産業ソリューションがあります:
Diclaimer-私はPushAppsで働いており、1年以上も自分のアプリケーションでその製品を使用しています。
これがまだ有用かどうかはわかりません。私はhttp://www.pushlets.com/の javaライブラリでこのようなことを達成しました
Althougをサービスで実行しても、Androidがシャットダウンしてリスナースレッドが強制終了されるのを防ぐことはできません。
C2DM:アプリユーザーはGmailアカウントを持っている必要があります。
MQTT:接続が1024に達すると、Linuxの「モデルの選択」を使用したため、動作が停止します。
Androidには無料のプッシュサービスとAPIがあり、試してみることができます:http : //push-notification.org
無料で簡単な方法:
ターゲットユーザーベースが大きくなく(1000未満)、無料のサービスを開始したい場合は、Airbopが最適で最も便利です。
Airbopウェブサイト は、APIを介してGoogleクラウドメッセージングサービスを使用し、優れたパフォーマンスを提供します。私は2つのプロジェクトで使用しており、簡単に実装できました。
およびUrbanshipのようなサービスは優れていますが、プッシュ通知だけでなく、デプロイメントスタック全体を提供します。
プッシュサービスのみがターゲットの場合、Airbopは正常に動作します。
私はPushwooshを使用していませんが、素晴らしい選択でもあります。1,000,000デバイスまで無料でプッシュできます
SMSとHTTPの両方を使用することをお勧めします。ユーザーがサインインしていない場合は、電話にSMSを送信して、メッセージが待機中であることを通知します。
これが、このエリクソンラボサービスのしくみです。https://labs.ericsson.com/apis/mobile-java-push/
これを自分で実装する場合、トリッキーな部分は、ユーザーに表示されずに着信SMSを削除することです。または、彼らがあなたのケースでそれを見た場合、それは大丈夫です。
次のように機能します: BroadCastReceiverを使用してSMSを削除する-Android
はい、このようなコードを書くことは危険である可能性があり、アプリケーションが必要のないSMSをアプリケーションが削除したため、誰かの人生を台無しにする可能性があります。
GoogleクラウドメッセージングまたはGCMを使用できます。無料で簡単に使用できます。また、PushWooshのようなサードパーティのプッシュサーバーを使用して、柔軟性を高めることもできます。
Firebase Cloud Messaging(FCM)はGCMの新しいバージョンです。FCMは、メッセージを安全かつ無料で送信できるクロスプラットフォームのメッセージングソリューションです。GCMの中央インフラストラクチャを継承して、Android、iOS、Web(JavaScript)、Unity、C ++でメッセージを確実に配信します。
2018年4月10日の時点で、GoogleはGCMを承認していません。GCMサーバーとクライアントAPIは非推奨であり、2019年4月11日に削除されます。GCMアプリケーションを、信頼性が高くスケーラブルなGCMインフラストラクチャを継承するFirebase Cloud Messaging(FCM)に移行することをお勧めします。