Heim  >  Artikel  >  Java  >  Eine Beispielerklärung für Jiguang Push Jpush

Eine Beispielerklärung für Jiguang Push Jpush

PHP中文网
PHP中文网Original
2017-06-21 16:51:064134Durchsuche

Über Jpush

Push ist eine wesentliche Funktion mobiler Apps. Dieses Mal muss ich sie aufgrund des Unternehmensprojekts studieren. Da Push normalerweise auf der Serverseite geschrieben wird, ist es für Javaweb-Programmierer, die Android nicht kennen, ein Problem, eine vollständige Demo zu schreiben. Deshalb werde ich hier als Referenz ein Beispiel von Anfang bis Ende schreiben. Da ich Android nicht verstehe, habe ich aufgrund der Projektanforderungen gerade eine Demo von Baidu erstellt. Es gibt viele Mängel und ich möchte nicht, dass Sie mich korrigieren.

1. Lassen Sie uns zunächst kurz vorstellen, was Aurora Push ist

① Warum Push benötigt wird: Um das Problem der Datensynchronisierung zu lösen, gibt es zwei häufig verwendete Methoden auf mobilen Plattformen. Eine besteht darin, die Daten regelmäßig auf dem Server abzufragen, was auch als Polling bezeichnet wird, und die andere darin, eine lange TCP-Verbindung zwischen dem Mobiltelefon und dem Server aufrechtzuerhalten. Wenn der Server Daten hat, werden diese in Echtzeit an den Client übertragen nennen wir Push. Da es beim Push technisch schwierig ist, lange Verbindungen im Mobilfunknetz aufrechtzuerhalten, und wenn die Anzahl der Benutzer zunimmt, sind viele Server erforderlich, um lange Verbindungen aufrechtzuerhalten, und die Kosten sind ebenfalls sehr hoch. Daher benötigen wir ein JAR-Paket eines Drittanbieters, um unseren Push-Service zu unterstützen. Wenn Sie mehr wissen möchten, lesen Sie bitte die offizielle Dokumentation von Aurora Push.

②Die beliebte Antwort von Jiguang Push: Der zu übertragende Inhalt wird durch Aufrufen der jpush-API an die jeweilige App gesendet Inhalte, die wir in der Vergangenheit vorangetrieben haben.

2. Quellcode

Servercode:

Android-Clientcode:

Die Android-Umgebung ist: ADT+SDK+Eclipse

ADT-Download:

SDK-Download:

Die erforderliche JDK-Umgebungsinstallation wird nicht einzeln beschrieben.

Hinweis: Der Code kann direkt importiert werden und muss nur an wenigen Stellen geändert werden, was später erläutert wird. Zuerst werde ich Ihnen beibringen, wie Sie die Android-Umgebung einrichten und sicherstellen, dass der Code erfolgreich importiert werden kann

3 Arbeitsschritte

① Installieren Sie das Plug-in

②SDK installieren

Nach Abschluss dieses Schritts wechselt die Seite zur Android-Entwicklungsoberfläche zwei weitere Dinge auf der Seite

Wählen Sie im Allgemeinen die Version aus, die Sie in Tools und Android benötigen Dann führe Sie zur Installation. Ich habe es hier nicht ausgewählt, daher ist es ausgegraut.

Hinweis: Wenn die Installation langsam ist oder fehlschlägt

gibt es zwei Methoden:

① Verwenden Sie die FQ-Software. Ich verwende Blue Light

② Verwenden Sie den Konfigurationsspiegelserver. Wie im Bild gezeigt:

③Dann importieren Sie das Android-Projekt (das serverseitige Projekt wird nicht beschrieben, wie es importiert wird)

Klicken Sie mit der rechten Maustaste in den leeren Bereich der Projektliste – wählen Sie Importieren – und gehen Sie dann vor wie angezeigt

Dann das Android-Programm ausführen (am besten das Datenkabel einstecken - USB-Debugging des Telefons einschalten - und dann los zurück zum Telefon, wenn das Programm ausgeführt wird)

Spezifisch Sie können es von Baidu herunterladen.

4. So verwenden Sie Aurora Push (Sie müssen ein Konto auf der offiziellen Website registrieren)

Informationen zur spezifischen Verwendung erhalten Sie bei Baidu oder auf der offiziellen Website . Unten sind die wichtigsten Screenshots

Appkey und Master Secret werden später verwendet

5. Ändern Sie die Android-Konfigurationsdatei und ändern Sie den Appkey in den Appkey von die von Ihnen hinzugefügte Anwendung

6. Servercode-Anzeige, die Codes sind alle kommentiert, daher werde ich sie nicht einzeln erklären

Nur ​​diese drei Codes verwenden

APPKET und MASTERSECRET werden in die Zeichenfolgen geändert, die generiert werden, wenn Sie die Anwendung im Jiguang Developer Service hinzufügen

  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 }
Code anzeigen

Nach dem Ausführen des Servercodes empfängt das Telefon Folgendes Benachrichtigung:

Tatsächlich sendet der Server die Benachrichtigung über den eindeutig identifizierten App-Schlüssel und das Hauptgeheimnis an den Aurora-Server, und der Server leitet sie dann an die entsprechende App weiter (Der App-Schlüssel ist ebenfalls vorhanden). konfiguriert in der Konfigurationsdatei der oben genannten App)

Es sind vielleicht nicht sehr detailliert, aber es sind zu viele Daher werde ich hier keine Screenshots einzeln erstellen.

Das obige ist der detaillierte Inhalt vonEine Beispielerklärung für Jiguang Push Jpush. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn