JPush Java SDK 示例代码与简要注释

2016-05-05  本文已影响3981人  jiminy

建议使用JPush 服务端SDK的人都先看下接口文档,了解推送api,具体链接:JPush v3 推送api文档

本人下载的是JPush Java 3.2.9版本的SDK源码(下载链接:JPush Java SDK 源码),在原PushExample类里面稍微改了下buildPushObject_all_all_alert方法,具体看代码:


public static void main(String[] args) {

testSendPush();

}

public static void testSendPush() {

JPushClient jpushClient = new JPushClient(masterSecret, appKey, 3);
PushPayload payload = buildPushObject_all_all_alert();
try {

PushResult result = jpushClient.sendPush(payload);

LOG.info("Got result - " + result);

} catch (APIConnectionException e) {

LOG.error("Connection error. Should retry later. ", e);

} catch (APIRequestException e) {

LOG.error("Error response from JPush server. Should review and fix it. ", e);

LOG.info("HTTP Status: " + e.getStatus());

LOG.info("Error Code: " + e.getErrorCode());

LOG.info("Error Message: " + e.getErrorMessage());

LOG.info("Msg ID: " + e.getMsgId());

}

}

public static PushPayload buildPushObject_all_all_alert() {

LOG.info("----------buildPushObject_all_all_alert");
IosAlert iosAlert =  IosAlert.newBuilder().setTitleAndBody("title", "alert body").build();//创建一个IosAlert对象,可指定APNs的alert、title等字段

return PushPayload.newBuilder()

.setPlatform(Platform.all())//指定要推送的平台,all代表当前应用配置了的所有平台,也可以传android等具体平台

.setAudience(Audience.all())//指定推送的接收对象,all代表所有人,也可以指定已经设置成功的tag或alias或该应应用客户端调用接口获取到的registration id

.setNotification(Notification.newBuilder()//jpush的通知,android的由jpush直接下发,iOS的由apns服务器下发,Winphone的由mpns下发

.addPlatformNotification(AndroidNotification.newBuilder()//指定当前推送的android通知

.setAlert("android notification alert")

.setTitle("android notification title")

.setBuilderId(1)//设置Android 通知样式,需要客户端先定义、设置了该样式才有效

.addExtra("extras key", "extras value")//此字段为透传字段,不会显示在通知栏。用户可以通过此字段来做一些定制需求,如特定的key传要指定跳转的页面(value)

.build())

.addPlatformNotification(IosNotification.newBuilder()//指定当前推送的iOS通知

.setAlert(iosAlert)//传一个IosAlert对象,指定apns title、title、subtitle等
//.setAlert("ios notification alert")//直接传alert

.incrBadge(1)//此项是指定此推送的badge自动加1。如果想直接传具体值,可把incrBadge换成setBadge。

.setSound("sound.caf")//此字段的值default表示系统默认声音;传sound.caf表示此推送以项目里面打包的sound.caf声音来提醒,如果系统没有此音频则以系统默认声音提醒;此字段如果传空字符串,iOS9及以上的系统是无声音提醒,以下的系统是默认声音

.addExtra("iOS 的extras1", "JPush111")//此字段为透传字段,不会显示在通知栏。用户可以通过此字段来做一些定制需求,如特定的key传要指定跳转的页面(value)

.setContentAvailable(true)//此项说明此推送是一个background推送,想了解background看:http://docs.jpush.io/client/ios_tutorials/#ios-7-background-remote-notification

.build())

.addPlatformNotification(WinphoneNotification.newBuilder()

.setAlert("WinPhone notification alert")

.setOpenPage("xxxx.cs")//指定点击打开的页面(类),具体后缀忘记,错了请指正

.addExtra("WinPhone extras key", "WinPhone extras value")

.build())

.build())

.setMessage(Message.newBuilder()//Platform指定了哪些平台就会像指定平台中符合推送条件的设备进行推送。 jpush的自定义消息,sdk默认不做任何处理,不会有通知提示。建议看文档http://docs.jpush.io/guideline/faq/的 [通知与自定义消息有什么区别?]了解通知和自定义消息的区别

.setMsgContent("message content")

.setTitle("message titile")

.addExtra("message extras key", "message extras value")

.build())

.setOptions(Options.newBuilder()

.setApnsProduction(false)//此字段的值是用来指定本推送要推送的apns环境,false表示开发,true表示生产;对android和自定义消息无意义

.setSendno(1)//此字段是给开发者自己给推送编号,方便推送者分辨推送记录

.setTimeToLive(86400)//此字段的值是用来指定本推送的离线保存时长,如果不传此字段则默认保存一天,最多指定保留十天;

.build())

.build();

}

请求结果如下:

16/05/05 18:45:58 INFO connection.NativeHttpClient: Created instance with connectionTimeout 5,000, readTimeout 30,000, maxRetryTimes 3, SSL Version TLS

16/05/05 18:45:58 INFO connection.NativeHttpClient: Created instance with connectionTimeout 5,000, readTimeout 30,000, maxRetryTimes 3, SSL Version TLS

16/05/05 18:45:58 INFO connection.NativeHttpClient: Created instance with connectionTimeout 5,000, readTimeout 30,000, maxRetryTimes 3, SSL Version TLS

16/05/05 18:45:58 INFO connection.NativeHttpClient: Created instance with connectionTimeout 5,000, readTimeout 30,000, maxRetryTimes 3, SSL Version TLS

16/05/05 18:45:58 INFO examples.PushExample: ----------buildPushObject_all_all_alert

16/05/05 18:45:58 DEBUG connection.NativeHttpClient: Send request - POST https://api.jpush.cn/v3/push

16/05/05 18:45:58 DEBUG connection.NativeHttpClient: Request Content - {"platform":"all","audience":"all","notification":{"android":{"alert":"android notification alert","extras":{"extras key":"extras value"},"title":"android notification title"},"winphone":{"alert":"WinPhone notification alert","extras":{"WinPhone extras key":"WinPhone extras value"},"_open_page":"xxxx.cs"},"ios":{"alert":"ios notification alert","extras":{"from":"JPush"},"badge":"+1","sound":"sound.caf","content-available":1}},"message":{"title":"message titile","msg_content":"message content","extras":{"message extras key":"message extras value"}},"options":{"sendno":1,"time_to_live":86400,"apns_production":false}}

16/05/05 18:46:04 DEBUG resp.ResponseWrapper: JPush API Rate Limiting params - quota:600, remaining:599, reset:60

16/05/05 18:46:04 DEBUG connection.NativeHttpClient: Succeed to get response OK - responseCode:200

16/05/05 18:46:04 DEBUG connection.NativeHttpClient: Response Content - {"sendno":"1","msg_id":"1588446452"}

16/05/05 18:46:04 INFO examples.PushExample: Got result - {"msg_id":1588446452,"sendno":1}

msg_id是jpush中此推送的唯一标识,如果对某推送有疑问可以向他们提供具体msg_id。

注:本人并不擅长写文档,此文仅给刚使用jpush 服务端sdk 开发者参考。如果写的不好,请谅解,提出改进建议。

上一篇下一篇

猜你喜欢

热点阅读