1. 程式人生 > >java 實現極光推送

java 實現極光推送

pom檔案需要新增


<dependency>
      <groupId>cn.jpush.api</groupId>
      <artifactId>jpush-client</artifactId>
      <version>3.3.3</version>
  </dependency>

    <dependency>
        <groupId>cn.jpush.api</groupId>
        <artifactId>jiguang-common</artifactId>
        <version>1.0.8</version>
    </dependency>
    <dependency>
        <groupId>io.netty</groupId>
        <artifactId>netty-all</artifactId>
        <version>4.1.6.Final</version>
        <scope>compile</scope>
    </dependency>
    <dependency>
        <groupId>com.google.code.gson</groupId>
        <artifactId>gson</artifactId>
        <version>2.3</version>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>1.7.7</version>
    </dependency>

    <!-- For log4j -->
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
        <version>1.7.7</version>
    </dependency>
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.17</version>
    </dependency>

接下來直接寫工具類呼叫  

import cn.jiguang.common.resp.APIConnectionException; import cn.jiguang.common.resp.APIRequestException; import cn.jpush.api.JPushClient; import cn.jpush.api.push.PushResult; import cn.jpush.api.push.model.Message; import cn.jpush.api.push.model.Options; import cn.jpush.api.push.model.Platform; import cn.jpush.api.push.model.PushPayload; import cn.jpush.api.push.model.audience.Audience; import cn.jpush.api.push.model.notification.*;     public class JpushClientUtil {       private final static String appKey = "你的appKey9c654aa03a5d70";       private final static String masterSecret = "你的masterSecret41806d5fd29e3c5";       private static JPushClient jPushClient = new JPushClient(masterSecret,appKey);       /**      * 推送給裝置標識引數的使用者      * @param registrationId 裝置標識      * @param notification_title 通知內容標題      * @param msg_title 訊息內容標題      * @param msg_content 訊息內容      * @param extrasparam 擴充套件欄位      * @return 0推送失敗,1推送成功      */     public static int sendToRegistrationId( String registrationId,String notification_title, String msg_title, String msg_content, String extrasparam) {         int result = 0;         try {             PushPayload pushPayload= JpushClientUtil.buildPushObject_all_registrationId_alertWithTitle(registrationId,notification_title,msg_title,msg_content,extrasparam);             System.out.println(pushPayload);             PushResult pushResult=jPushClient.sendPush(pushPayload);             System.out.println(pushResult);             if(pushResult.getResponseCode()==200){                 result=1;             }         } catch (APIConnectionException e) {             e.printStackTrace();           } catch (APIRequestException e) {             e.printStackTrace();         }            return result;     }       /**      * 傳送給所有安卓使用者      * @param notification_title 通知內容標題      * @param msg_title 訊息內容標題      * @param msg_content 訊息內容      * @param extrasparam 擴充套件欄位      * @return 0推送失敗,1推送成功      */     public static int sendToAllAndroid( String notification_title, String msg_title, String msg_content, String extrasparam) {         int result = 0;         try {             PushPayload pushPayload= JpushClientUtil.buildPushObject_android_all_alertWithTitle(notification_title,msg_title,msg_content,extrasparam);             System.out.println(pushPayload);             PushResult pushResult=jPushClient.sendPush(pushPayload);             System.out.println(pushResult);             if(pushResult.getResponseCode()==200){                 result=1;             }         } catch (Exception e) {               e.printStackTrace();         }            return result;     }       /**      * 傳送給所有IOS使用者      * @param notification_title 通知內容標題      * @param msg_title 訊息內容標題      * @param msg_content 訊息內容      * @param extrasparam 擴充套件欄位      * @return 0推送失敗,1推送成功      */     public static int sendToAllIos(String notification_title, String msg_title, String msg_content, String extrasparam) {         int result = 0;         try {             PushPayload pushPayload= JpushClientUtil.buildPushObject_ios_all_alertWithTitle(notification_title,msg_title,msg_content,extrasparam);             System.out.println(pushPayload);             PushResult pushResult=jPushClient.sendPush(pushPayload);             System.out.println(pushResult);             if(pushResult.getResponseCode()==200){                 result=1;             }         } catch (Exception e) {               e.printStackTrace();         }            return result;     }       /**      * 傳送給所有使用者      * @param notification_title 通知內容標題      * @param msg_title 訊息內容標題      * @param msg_content 訊息內容      * @param extrasparam 擴充套件欄位      * @return 0推送失敗,1推送成功      */     public static int sendToAll( String notification_title, String msg_title, String msg_content, String extrasparam) {         int result = 0;         try {             PushPayload pushPayload= JpushClientUtil.buildPushObject_android_and_ios(notification_title,msg_title,msg_content,extrasparam);             System.out.println(pushPayload);             PushResult pushResult=jPushClient.sendPush(pushPayload);             System.out.println(pushResult);             if(pushResult.getResponseCode()==200){                 result=1;             }         } catch (Exception e) {               e.printStackTrace();         }           return result;     }           public static PushPayload buildPushObject_android_and_ios(String notification_title, String msg_title, String msg_content, String extrasparam) {         return PushPayload.newBuilder()                 .setPlatform(Platform.android_ios())                 .setAudience(Audience.all())                 .setNotification(Notification.newBuilder()                         .setAlert(notification_title)                         .addPlatformNotification(AndroidNotification.newBuilder()                                 .setAlert(notification_title)                                 .setTitle(notification_title)                                 //此欄位為透傳欄位,不會顯示在通知欄。使用者可以通過此欄位來做一些定製需求,如特定的key傳要指定跳轉的頁面(value)                                 .addExtra("androidNotification extras key",extrasparam)                                 .build()                         )                         .addPlatformNotification(IosNotification.newBuilder()                                 //傳一個IosAlert物件,指定apns title、title、subtitle等                                 .setAlert(notification_title)                                 //直接傳alert                                 //此項是指定此推送的badge自動加1                                 .incrBadge(1)                                 //此欄位的值default表示系統預設聲音;傳sound.caf表示此推送以專案裡面打包的sound.caf聲音來提醒,                                 // 如果系統沒有此音訊則以系統預設聲音提醒;此欄位如果傳空字串,iOS9及以上的系統是無聲音提醒,以下的系統是預設聲音                                 .setSound("sound.caf")                                 //此欄位為透傳欄位,不會顯示在通知欄。使用者可以通過此欄位來做一些定製需求,如特定的key傳要指定跳轉的頁面(value)                                 .addExtra("iosNotification extras key",extrasparam)                                 //此項說明此推送是一個background推送,想了解background看:http://docs.jpush.io/client/ios_tutorials/#ios-7-background-remote-notification                                 // .setContentAvailable(true)                                   .build()                         )                         .build()                 )                 //Platform指定了哪些平臺就會像指定平臺中符合推送條件的裝置進行推送。 jpush的自定義訊息,                 // sdk預設不做任何處理,不會有通知提示。建議看文件http://docs.jpush.io/guideline/faq/的                 // [通知與自定義訊息有什麼區別?]瞭解通知和自定義訊息的區別                 .setMessage(Message.newBuilder()                         .setMsgContent(msg_content)                         .setTitle(msg_title)                         .addExtra("message extras key",extrasparam)                         .build())                   .setOptions(Options.newBuilder()                         //此欄位的值是用來指定本推送要推送的apns環境,false表示開發,true表示生產;對android和自定義訊息無意義                         .setApnsProduction(false)                         //此欄位是給開發者自己給推送編號,方便推送者分辨推送記錄                         .setSendno(1)                         //此欄位的值是用來指定本推送的離線儲存時長,如果不傳此欄位則預設儲存一天,最多指定保留十天,單位為秒                         .setTimeToLive(86400)                         .build()                 )                 .build();     }       private static PushPayload buildPushObject_all_registrationId_alertWithTitle(String registrationId,String notification_title, String msg_title, String msg_content, String extrasparam) {           System.out.println("----------buildPushObject_all_all_alert");         //建立一個IosAlert物件,可指定APNs的alert、title等欄位         //IosAlert iosAlert =  IosAlert.newBuilder().setTitleAndBody("title", "alert body").build();           return PushPayload.newBuilder()                 //指定要推送的平臺,all代表當前應用配置了的所有平臺,也可以傳android等具體平臺                 .setPlatform(Platform.all())                 //指定推送的接收物件,all代表所有人,也可以指定已經設定成功的tag或alias或該應應用客戶端呼叫介面獲取到的registration id                 .setAudience(Audience.registrationId(registrationId))                 //jpush的通知,android的由jpush直接下發,iOS的由apns伺服器下發,Winphone的由mpns下發                 .setNotification(Notification.newBuilder()                         //指定當前推送的android通知                         .addPlatformNotification(AndroidNotification.newBuilder()                                   .setAlert(notification_title)                                 .setTitle(notification_title)                                 //此欄位為透傳欄位,不會顯示在通知欄。使用者可以通過此欄位來做一些定製需求,如特定的key傳要指定跳轉的頁面(value)                                 .addExtra("androidNotification extras key",extrasparam)                                   .build())                         //指定當前推送的iOS通知                         .addPlatformNotification(IosNotification.newBuilder()                                 //傳一個IosAlert物件,指定apns title、title、subtitle等                                 .setAlert(notification_title)                                 //直接傳alert                                 //此項是指定此推送的badge自動加1                                 .incrBadge(1)                                 //此欄位的值default表示系統預設聲音;傳sound.caf表示此推送以專案裡面打包的sound.caf聲音來提醒,                                 // 如果系統沒有此音訊則以系統預設聲音提醒;此欄位如果傳空字串,iOS9及以上的系統是無聲音提醒,以下的系統是預設聲音                                 .setSound("sound.caf")                                 //此欄位為透傳欄位,不會顯示在通知欄。使用者可以通過此欄位來做一些定製需求,如特定的key傳要指定跳轉的頁面(value)                                 .addExtra("iosNotification extras key",extrasparam)                                 //此項說明此推送是一個background推送,想了解background看:http://docs.jpush.io/client/ios_tutorials/#ios-7-background-remote-notification                                 //取消此註釋,訊息推送時ios將無法在鎖屏情況接收                                 // .setContentAvailable(true)                                   .build())                             .build())                 //Platform指定了哪些平臺就會像指定平臺中符合推送條件的裝置進行推送。 jpush的自定義訊息,                 // sdk預設不做任何處理,不會有通知提示。建議看文件http://docs.jpush.io/guideline/faq/的                 // [通知與自定義訊息有什麼區別?]瞭解通知和自定義訊息的區別                 .setMessage(Message.newBuilder()                           .setMsgContent(msg_content)                           .setTitle(msg_title)                           .addExtra("message extras key",extrasparam)                           .build())                   .setOptions(Options.newBuilder()                         //此欄位的值是用來指定本推送要推送的apns環境,false表示開發,true表示生產;對android和自定義訊息無意義                         .setApnsProduction(false)                         //此欄位是給開發者自己給推送編號,方便推送者分辨推送記錄                         .setSendno(1)                         //此欄位的值是用來指定本推送的離線儲存時長,如果不傳此欄位則預設儲存一天,最多指定保留十天;                         .setTimeToLive(86400)                           .build())                   .build();       }       private static PushPayload buildPushObject_android_all_alertWithTitle(String notification_title, String msg_title, String msg_content, String extrasparam) {         System.out.println("----------buildPushObject_android_registrationId_alertWithTitle");         return PushPayload.newBuilder()                 //指定要推送的平臺,all代表當前應用配置了的所有平臺,也可以傳android等具體平臺                 .setPlatform(Platform.android())                 //指定推送的接收物件,all代表所有人,也可以指定已經設定成功的tag或alias或該應應用客戶端呼叫介面獲取到的registration id                 .setAudience(Audience.all())                 //jpush的通知,android的由jpush直接下發,iOS的由apns伺服器下發,Winphone的由mpns下發                 .setNotification(Notification.newBuilder()                         //指定當前推送的android通知                         .addPlatformNotification(AndroidNotification.newBuilder()                                 .setAlert(notification_title)                                 .setTitle(notification_title)                                 //此欄位為透傳欄位,不會顯示在通知欄。使用者可以通過此欄位來做一些定製需求,如特定的key傳要指定跳轉的頁面(value)                                 .addExtra("androidNotification extras key",extrasparam)                                 .build())                         .build()                 )                 //Platform指定了哪些平臺就會像指定平臺中符合推送條件的裝置進行推送。 jpush的自定義訊息,                 // sdk預設不做任何處理,不會有通知提示。建議看文件http://docs.jpush.io/guideline/faq/的                 // [通知與自定義訊息有什麼區別?]瞭解通知和自定義訊息的區別                 .setMessage(Message.newBuilder()                         .setMsgContent(msg_content)                         .setTitle(msg_title)                         .addExtra("message extras key",extrasparam)                         .build())                   .setOptions(Options.newBuilder()                         //此欄位的值是用來指定本推送要推送的apns環境,false表示開發,true表示生產;對android和自定義訊息無意義                         .setApnsProduction(false)                         //此欄位是給開發者自己給推送編號,方便推送者分辨推送記錄                         .setSendno(1)                         //此欄位的值是用來指定本推送的離線儲存時長,如果不傳此欄位則預設儲存一天,最多指定保留十天,單位為秒                         .setTimeToLive(86400)                         .build())                 .build();     }       private static PushPayload buildPushObject_ios_all_alertWithTitle( String notification_title, String msg_title, String msg_content, String extrasparam) {         System.out.println("----------buildPushObject_ios_registrationId_alertWithTitle");         return PushPayload.newBuilder()                 //指定要推送的平臺,all代表當前應用配置了的所有平臺,也可以傳android等具體平臺                 .setPlatform(Platform.ios())                 //指定推送的接收物件,all代表所有人,也可以指定已經設定成功的tag或alias或該應應用客戶端呼叫介面獲取到的registration id                 .setAudience(Audience.all())                 //jpush的通知,android的由jpush直接下發,iOS的由apns伺服器下發,Winphone的由mpns下發                 .setNotification(Notification.newBuilder()                         //指定當前推送的android通知                         .addPlatformNotification(IosNotification.newBuilder()                                 //傳一個IosAlert物件,指定apns title、title、subtitle等                                 .setAlert(notification_title)                                 //直接傳alert                                 //此項是指定此推送的badge自動加1                                 .incrBadge(1)                                 //此欄位的值default表示系統預設聲音;傳sound.caf表示此推送以專案裡面打包的sound.caf聲音來提醒,                                 // 如果系統沒有此音訊則以系統預設聲音提醒;此欄位如果傳空字串,iOS9及以上的系統是無聲音提醒,以下的系統是預設聲音                                 .setSound("sound.caf")                                 //此欄位為透傳欄位,不會顯示在通知欄。使用者可以通過此欄位來做一些定製需求,如特定的key傳要指定跳轉的頁面(value)                                 .addExtra("iosNotification extras key",extrasparam)                                 //此項說明此推送是一個background推送,想了解background看:http://docs.jpush.io/client/ios_tutorials/#ios-7-background-remote-notification                                // .setContentAvailable(true)                                   .build())                         .build()                 )                 //Platform指定了哪些平臺就會像指定平臺中符合推送條件的裝置進行推送。 jpush的自定義訊息,                 // sdk預設不做任何處理,不會有通知提示。建議看文件http://docs.jpush.io/guideline/faq/的                 // [通知與自定義訊息有什麼區別?]瞭解通知和自定義訊息的區別                 .setMessage(Message.newBuilder()                         .setMsgContent(msg_content)                         .setTitle(msg_title)                         .addExtra("message extras key",extrasparam)                         .build())                   .setOptions(Options.newBuilder()                         //此欄位的值是用來指定本推送要推送的apns環境,false表示開發,true表示生產;對android和自定義訊息無意義                         .setApnsProduction(false)                         //此欄位是給開發者自己給推送編號,方便推送者分辨推送記錄                         .setSendno(1)                         //此欄位的值是用來指定本推送的離線儲存時長,如果不傳此欄位則預設儲存一天,最多指定保留十天,單位為秒                         .setTimeToLive(86400)                         .build())                 .build();     }   //    public static void main(String[] args){ //        if(JpushClientUtil.sendToAllIos("testIos","testIos","this is a ios Dev test","")==1){ //            System.out.println("success"); //        } //    } }