ホームページ >Java >&#&チュートリアル >Jiguang Push Jpush の例の説明

Jiguang Push Jpush の例の説明

PHP中文网
PHP中文网オリジナル
2017-06-21 16:51:064245ブラウズ

Jpushについて

Pushはモバイルアプリに欠かせない機能です。今回は会社のプロジェクトのため勉強する必要があります。通常、プッシュはサーバー側で記述されるため、Android を知らない Javaweb プログラマーにとって完全なデモを作成するのは頭の痛い問題です。そこで、参考までに最初から最後までの例をここに書きます。私は Android を理解していないので、プロジェクトの必要性から Baidu からデモを作成しただけです。欠点がたくさんあるので、修正してほしくないのです。

1. まず、Aurora Push とは何かを簡単に紹介します

① プッシュが必要な理由: データ同期の問題を解決するために、モバイル プラットフォームで一般的に使用される 2 つの方法があります。 1 つは、ポーリングとも呼ばれるサーバー上のデータを定期的にクエリすることです。もう 1 つは、携帯電話とサーバーの間で長時間の TCP 接続を維持することです。サーバーにデータがある場合、そのデータはリアルタイムでクライアントにプッシュされます。それはプッシュと呼ばれるものです。モバイルネットワークではプッシュ時に長時間接続を維持することが技術的に難しく、ユーザー数が増えると長時間接続を維持するために多数のサーバーが必要となり、コストも非常に高くなります。したがって、プッシュ サービスをサポートするにはサードパーティの jar パッケージが必要です。さらに詳しく知りたい場合は、Aurora Push の公式ドキュメントを参照してください。

②Jiguang Push の一般的な回答: jpush API を呼び出して、プッシュする必要があるコンテンツを Jiguang Push サーバーに送信します。Jiguang Push サーバーは、プッシュしたコンテンツに基づいて、特定のアプリにプッシュすることを選択します。過去に。

2. ソースコード

サーバーコード:

Androidクライアントコード:

Android環境: ADT+SDK+eclipse

ADTダウンロード:

SDKダウンロード:

必要なJDK環境がインストールされていますそれらを一つ一つ説明することはできません。

注: コードは直接インポートでき、いくつかの箇所を変更するだけで済みます。これについては後で説明します。まず、Android 環境をセットアップし、コードが正常にインポートされることを確認する方法を説明します

3. 操作手順

① プラグインをインストールします

②sdkをインストールします

このステップが完了すると、ページはAndroid開発インターフェースに切り替わります

選択[ツール] でインストールする一般的な選択と必要な Android のバージョンを選択すると、ここでは選択していないため、グレー表示されます。

注: インストールが遅い、またはインストールが失敗する場合

2 つの方法があります:

① FQ ソフトウェアを使用する ブルーライトを使用します

② 構成ミラー サーバーを使用します 図に示すように:

③ 次に、Android プロジェクトをインポートします (サーバーサイドプロジェクトのインポート方法は説明しません)

プロジェクトリストの空白部分を右クリックし、インポートを選択し、図のように操作します

次に、Android プログラムを実行します (データ ケーブルを接続し、携帯電話の USB デバッグをオンにし、プログラムの実行中に携帯電話にダウンロードするのが最善です)

からダウンロードできます。詳細については百度をご覧ください。

4. Aurora Push の使用方法 (公式 Web サイトでアカウントを登録する必要があります)

具体的な使用方法については、Baidu を参照するか、公式 Web サイトを参照してください。 以下は主なスクリーンショットです

appkey。マスターシークレットは後で使用します

5、Android設定ファイルを変更し、アプリキーを追加したアプリケーションのアプリキーに変更します

6.サーバーコードの表示、コードはすべてコメント化されているので、勝ちました一つ一つ説明する必要はありません

この3つだけを使用してください コード

APPKETとMASTERSECRETを、Jiguang Developer Serviceでアプリケーションを追加したときに生成された文字列に変更してください

  1  package com.uxun.serviceImpl;  2   3 import com.uxun.service.JPushService;  4   5 import cn.jiguang.common.resp.APIConnectionException;  6 import cn.jiguang.common.resp.APIRequestException;  7 import cn.jpush.api.JPushClient;  8 import cn.jpush.api.push.PushResult;  9 import cn.jpush.api.push.model.Platform; 10 import cn.jpush.api.push.model.PushPayload; 11 import cn.jpush.api.push.model.audience.Audience; 12 import cn.jpush.api.push.model.notification.AndroidNotification; 13 import cn.jpush.api.push.model.notification.IosNotification; 14 import cn.jpush.api.push.model.notification.Notification; 15  16 public class JPushServiceImpl implements JPushService { 17  18     private final static String APPKET = "44262636e2afd75d9b9f7932"; 19      20     private final static String  MASTERSECRET = "ae5c0ab5f093b2aba1f8ce25"; 21   22     private static JPushClient jPushClient = new JPushClient(MASTERSECRET, APPKET);//通知默认保留24小时。 23      24     @Override 25     public int sendToRegistrationId(String registrationId, String notification_alert, String notification_title, 26             String extrasparam) { 27         int result = 0; 28         try { 29             PushPayload pushPayload= JPushServiceImpl.buildPushObjectWithRegistrationId(registrationId, 30                     notification_alert, notification_title, extrasparam); 31             System.out.println(pushPayload); 32             PushResult pushResult=jPushClient.sendPush(pushPayload);  //发送推送对象 33             //System.out.println(pushResult); 34             if(pushResult.getResponseCode() == 200) {  //状态码等于200 为成功 35                 result=1; 36             } 37         } catch (APIConnectionException e) { 38             e.printStackTrace(); 39         } catch (APIRequestException e) { 40             e.printStackTrace(); 41         } 42          43          return result; 44     } 45  46     @Override 47     public int sendToAll(String notification_alert, String notification_title, String extrasparam) { 48         int result = 0; 49         try { 50             PushPayload pushPayload= JPushServiceImpl.buildPushObjectWithAll(notification_alert, 51                     notification_title, extrasparam); 52             System.out.println(pushPayload); 53             PushResult pushResult=jPushClient.sendPush(pushPayload);  //发送推送对象 54             //System.out.println(pushResult); 55             if(pushResult.getResponseCode() == 200) {  //状态码等于200 为成功 56                 result=1; 57             } 58         } catch (APIConnectionException e) { 59             e.printStackTrace(); 60         } catch (APIRequestException e) { 61             e.printStackTrace(); 62         } 63          64          return result; 65     } 66      67     @Override 68     public int sendToAllIos(String notification_alert, String notification_title, String extrasparam) { 69          70         int result = 0; 71         try { 72             PushPayload pushPayload= JPushServiceImpl.buildPushObjectWithIos(notification_alert, 73                     notification_title, extrasparam); 74             System.out.println(pushPayload); 75             PushResult pushResult=jPushClient.sendPush(pushPayload);  //发送推送对象 76             //System.out.println(pushResult); 77             if(pushResult.getResponseCode() == 200) {  //状态码等于200 为成功 78                 result=1; 79             } 80         } catch (APIConnectionException e) { 81             e.printStackTrace(); 82         } catch (APIRequestException e) { 83             e.printStackTrace(); 84         } 85          86          return result; 87     } 88  89     @Override 90     public int sendToAllAndroid(String notification_alert, String notification_title, String extrasparam) { 91          92         int result = 0; 93         try { 94             PushPayload pushPayload= JPushServiceImpl.buildPushObjectWithAndroid(notification_alert, 95                     notification_title, extrasparam); 96             System.out.println(pushPayload); 97             PushResult pushResult=jPushClient.sendPush(pushPayload);  //发送推送对象 98             //System.out.println(pushResult); 99             if(pushResult.getResponseCode() == 200) {  //状态码等于200 为成功100                 result=1;101             }102         } catch (APIConnectionException e) {103             e.printStackTrace();104         } catch (APIRequestException e) {105             e.printStackTrace();106         }107         108          return result;109     }110 111     /**112      * 建立以唯一设备标识符推送的对象113      * @param registrationId  唯一设备标识114      * @param notification_alert  通知内容115      * @param notification_title  通知标题116      * @param extrasparam  扩展字段117      * @return  返回推送对象118      */119     private static PushPayload buildPushObjectWithRegistrationId(String registrationId, String notification_alert, String notification_title,120             String extrasparam) {121         return PushPayload.newBuilder()122                 //指定要推送的平台,all代表当前应用配置了的所有平台,也可以传android等具体平台123                 .setPlatform(Platform.all())124                 //指定推送的接收对象,all代表所有人,也可以指定已经设置成功的tag或alias或该应应用客户端调用接口获取到的registration id125                 .setAudience(Audience.registrationId(registrationId))126                 //jpush的通知,android的由jpush直接下发,iOS的由apns服务器下发,Winphone的由mpns下发127                 .setNotification(Notification.newBuilder()128                 //指定当前推送的android通知129                 .addPlatformNotification(AndroidNotification.newBuilder()130                     .setAlert(notification_alert)   //设置通知内容(必填)131                     .setTitle(notification_title)    //设置通知标题(可选)132                     //此字段为透传字段,不会显示在通知栏。用户可以通过此字段来做一些定制需求,如特定的key传要指定跳转的页面(value)133                     .addExtra("androidNotification extras key",extrasparam)134                     .build())135                     136                 //指定当前推送的iOS通知137                 .addPlatformNotification(IosNotification.newBuilder()138                     //传一个IosAlert对象,指定apns title、title、subtitle等139                     .setAlert(notification_alert)140                     //直接传alert141                     //此项是指定此推送的badge(应用角标)自动加1142                     .incrBadge(1)143                     //此字段的值default表示系统默认声音;传sound.caf表示此推送以项目里面打包的sound.caf声音来提醒,144                     // 如果系统没有此音频则以系统默认声音提醒;此字段如果传空字符串,iOS9及以上的系统是无声音提醒,以下的系统是默认声音145                     .setSound("sound.caf")146                     //此字段为透传字段,不会显示在通知栏。用户可以通过此字段来做一些定制需求,如特定的key传要指定跳转的页面(value)147                     .addExtra("iosNotification extras key",extrasparam)148                     //此项说明此推送是一个background推送,想了解background看:http://docs.jpush.io/client/ios_tutorials/#ios-7-background-remote-notification149                     //取消此注释,消息推送时ios将无法在锁屏情况接收150                     // .setContentAvailable(true)151                     .build())152                 153                 //指定当前推送的winPhone通知154                 /*.addPlatformNotification(WinphoneNotification.newBuilder()155                       .setAlert(notification_alert)156                       //.setTitle(""))  //设置通知标题(可选)此标题将取代显示app名称的地方157                     .build())*/158                     .build())159                     .build();160     }161     162     /**163      * 建立推送所有用户的推送对象164      * @param notification_alert  通知内容165      * @param notification_title  通知标题166      * @param extrasparam  扩展字段167      * @return  返回推送对象168      */169     private static PushPayload buildPushObjectWithAll(String notification_alert,170             String notification_title, String extrasparam) {171         return PushPayload.newBuilder()172                 //指定要推送的平台,all代表当前应用配置了的所有平台,也可以传android等具体平台173                 .setPlatform(Platform.all())174                 //指定推送的接收对象,all代表所有人,也可以指定已经设置成功的tag或alias或该应应用客户端调用接口获取到的registration id175                 .setAudience(Audience.all())176                 //jpush的通知,android的由jpush直接下发,iOS的由apns服务器下发,Winphone的由mpns下发177                 .setNotification(Notification.newBuilder()178                 //指定当前推送的android通知179                 .addPlatformNotification(AndroidNotification.newBuilder()180                     .setAlert(notification_alert)   //设置通知内容(必填)181                     .setTitle(notification_title)    //设置通知标题(可选)182                     //此字段为透传字段,不会显示在通知栏。用户可以通过此字段来做一些定制需求,如特定的key传要指定跳转的页面(value)183                     .addExtra("androidNotification extras key",extrasparam)184                     .build())185                     186                 //指定当前推送的iOS通知187                 .addPlatformNotification(IosNotification.newBuilder()188                     //传一个IosAlert对象,指定apns title、title、subtitle等189                     .setAlert(notification_alert)190                     //直接传alert191                     //此项是指定此推送的badge(应用角标)自动加1192                     .incrBadge(1)193                     //此字段的值default表示系统默认声音;传sound.caf表示此推送以项目里面打包的sound.caf声音来提醒,194                     // 如果系统没有此音频则以系统默认声音提醒;此字段如果传空字符串,iOS9及以上的系统是无声音提醒,以下的系统是默认声音195                     .setSound("sound.caf")196                     //此字段为透传字段,不会显示在通知栏。用户可以通过此字段来做一些定制需求,如特定的key传要指定跳转的页面(value)197                     .addExtra("iosNotification extras key",extrasparam)198                     //此项说明此推送是一个background推送,想了解background看:http://docs.jpush.io/client/ios_tutorials/#ios-7-background-remote-notification199                     //取消此注释,消息推送时ios将无法在锁屏情况接收200                     // .setContentAvailable(true)201                     .build())202                 203                 //指定当前推送的winPhone通知204                 /*.addPlatformNotification(WinphoneNotification.newBuilder()205                       .setAlert(notification_alert)206                       //.setTitle(""))  //设置通知标题(可选)此标题将取代显示app名称的地方207                     .build())*/208                     .build())209                     .build();210     }211     212     /**213      * 建立推送所有ios用户的推送对象214      * @param notification_alert  通知内容215      * @param notification_title  通知标题216      * @param extrasparam  扩展字段217      * @return  返回推送对象218      */219     private static PushPayload buildPushObjectWithIos(String notification_alert,220             String notification_title, String extrasparam) {221         return PushPayload.newBuilder()222                 //指定要推送的平台,all代表当前应用配置了的所有平台,也可以传android等具体平台223                 .setPlatform(Platform.ios())224                 //指定推送的接收对象,all代表所有人,也可以指定已经设置成功的tag或alias或该应应用客户端调用接口获取到的registration id225                 .setAudience(Audience.all())226                 //jpush的通知,android的由jpush直接下发,iOS的由apns服务器下发,Winphone的由mpns下发227                 .setNotification(Notification.newBuilder()228                     229                 //指定当前推送的iOS通知230                 .addPlatformNotification(IosNotification.newBuilder()231                     //传一个IosAlert对象,指定apns title、title、subtitle等232                     .setAlert(notification_alert)233                     //直接传alert234                     //此项是指定此推送的badge(应用角标)自动加1235                     .incrBadge(1)236                     //此字段的值default表示系统默认声音;传sound.caf表示此推送以项目里面打包的sound.caf声音来提醒,237                     // 如果系统没有此音频则以系统默认声音提醒;此字段如果传空字符串,iOS9及以上的系统是无声音提醒,以下的系统是默认声音238                     .setSound("sound.caf")239                     //此字段为透传字段,不会显示在通知栏。用户可以通过此字段来做一些定制需求,如特定的key传要指定跳转的页面(value)240                     .addExtra("iosNotification extras key",extrasparam)241                     //此项说明此推送是一个background推送,想了解background看:http://docs.jpush.io/client/ios_tutorials/#ios-7-background-remote-notification242                     //取消此注释,消息推送时ios将无法在锁屏情况接收243                     // .setContentAvailable(true)244                     .build())245                     .build())246                     .build();247     }248     249     /**250      * 建立推送所有安卓用户的推送对象251      * @param notification_alert  通知内容252      * @param notification_title  通知标题253      * @param extrasparam  扩展字段254      * @return  返回推送对象255      */256     private static PushPayload buildPushObjectWithAndroid(String notification_alert,257             String notification_title, String extrasparam) {258         return PushPayload.newBuilder()259                 //指定要推送的平台,all代表当前应用配置了的所有平台,也可以传android等具体平台260                 .setPlatform(Platform.android())261                 //指定推送的接收对象,all代表所有人,也可以指定已经设置成功的tag或alias或该应应用客户端调用接口获取到的registration id262                 .setAudience(Audience.all())263                 //jpush的通知,android的由jpush直接下发,iOS的由apns服务器下发,Winphone的由mpns下发264                 .setNotification(Notification.newBuilder()265                     //指定当前推送的android通知266                     .addPlatformNotification(AndroidNotification.newBuilder()267                         .setAlert(notification_alert)   //设置通知内容(必填)268                         .setTitle(notification_title)    //设置通知标题(可选)269                         //此字段为透传字段,不会显示在通知栏。用户可以通过此字段来做一些定制需求,如特定的key传要指定跳转的页面(value)270                         .addExtra("androidNotification extras key",extrasparam)271                         .build())272                         .build())273                         .build();274     }275 276     277 278 }
コードを表示

サーバーコードを実行すると、電話は次の通知を受け取ります:

実際、サーバーは一意に識別されたアプリキーとマスターシークレットを介してAuroraサーバーに通知を送信します。 、そしてサーバーはそれを対応するアプリに転送します (appkey も上記のアプリの設定ファイルで設定されています)

具体的な操作は非常に多く、あまり詳しくないかもしれませんが、手順が多すぎるため、スクリーンショットを 1 つずつ撮りません。ここでは、具体的な手順のほとんどを示すだけです。

以上がJiguang Push Jpush の例の説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。