importjava.util.Map;importorg.apache.commons.logging.Log;importcn.jiguang.common.resp.APIConnectionException;importcn.jiguang.common.resp.APIRequestException;importcn.jpush.api.JPushClient;importcn.jpush.api.push.PushResult;importcn.jpush.api.push.model.Message;importcn.jpush.api.push.model.Options;importcn.jpush.api.push.model.Platform;importcn.jpush.api.push.model.PushPayload;importcn.jpush.api.push.model.audience.Audience;importcn.jpush.api.push.model.notification.AndroidNotification;importcn.jpush.api.push.model.notification.IosNotification;importcn.jpush.api.push.model.notification.Notification;public classJpushClientUtil {
@Loggerprivate staticLog log ;private final static String appKey = "";private final static String masterSecret = "";private static JPushClient jPushClient = newJPushClient(masterSecret,appKey);/*** 推送给设备标识参数的用户
*@paramregistrationId 设备标识
*@paramnotification_title 通知内容标题
*@parammsg_title 消息内容标题
*@parammsg_content 消息内容
*@paramextrasparam 扩展字段
*@return0推送失败,1推送成功
* 推送消息调用该方法*/
public static intsendToRegistrationId( String registrationId,String notification_title, String msg_title, String msg_content, Map 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) {if(log.isErrorEnabled()){
log.error("连接错误,稍后尝试" +e);
}
e.printStackTrace();
}catch(APIRequestException e) {if(log.isErrorEnabled()){
log.error("极光推送内部错误", e);
log.info("网络请求状态" +e.getStatus());
log.info("错误状态码" +e.getErrorCode());
log.info("错误信息" +e.getErrorMessage());
log.info("信息ID" +e.getMsgId());
}
e.printStackTrace();
}returnresult;
}/*** 发送给所有安卓用户
*@paramnotification_title 通知内容标题
*@parammsg_title 消息内容标题
*@parammsg_content 消息内容
*@paramextrasparam 扩展字段
*@return0推送失败,1推送成功*/
public static intsendToAllAndroid( 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();
}returnresult;
}/*** 发送给所有IOS用户
*@paramnotification_title 通知内容标题
*@parammsg_title 消息内容标题
*@parammsg_content 消息内容
*@paramextrasparam 扩展字段
*@return0推送失败,1推送成功*/
public static intsendToAllIos(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();
}returnresult;
}/*** 发送给所有用户
*@paramnotification_title 通知内容标题
*@parammsg_title 消息内容标题
*@parammsg_content 消息内容
*@paramextrasparam 扩展字段
*@return0推送失败,1推送成功*/
public static intsendToAll( 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();
}returnresult;
}public staticPushPayload buildPushObject_android_and_ios(String notification_title, String msg_title, String msg_content, String extrasparam) {returnPushPayload.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 staticPushPayload buildPushObject_all_registrationId_alertWithTitle(String registrationId,String notification_title, String msg_title, String msg_content, Map extrasparam) {
System.out.println("----------buildPushObject_all_all_alert");//创建一个IosAlert对象,可指定APNs的alert、title等字段//IosAlert iosAlert = IosAlert.newBuilder().setTitleAndBody("title", "alert body").build();
returnPushPayload.newBuilder()//指定要推送的平台,all代表当前应用配置了的所有平台,也可以传android等具体平台
.setPlatform(Platform.all())//指定推送的接收对象,all代表所有人,也可以指定已经设置成功的tag或alias或该应应用客户端调用接口获取到的registration id//.setAudience(Audience.registrationId(registrationId))
.setAudience(Audience.alias(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)//TODO可以传map
.addExtras(extrasparam)
.build())
.setOptions(Options.newBuilder()//此字段的值是用来指定本推送要推送的apns环境,false表示开发,true表示生产;对android和自定义消息无意义
.setApnsProduction(false)//此字段是给开发者自己给推送编号,方便推送者分辨推送记录
.setSendno(1)//此字段的值是用来指定本推送的离线保存时长,如果不传此字段则默认保存一天,最多指定保留十天;
.setTimeToLive(86400)
.build())
.build();
}private staticPushPayload buildPushObject_android_all_alertWithTitle(String notification_title, String msg_title, String msg_content, String extrasparam) {
System.out.println("----------buildPushObject_android_registrationId_alertWithTitle");returnPushPayload.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 staticPushPayload buildPushObject_ios_all_alertWithTitle( String notification_title, String msg_title, String msg_content, String extrasparam) {
System.out.println("----------buildPushObject_ios_registrationId_alertWithTitle");returnPushPayload.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)//.addExtra("order", 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)/*.addExtra("orderId","123456789")
.addExtra("customer","李白")
.addExtra("remark","测试")*/.build())
.setOptions(Options.newBuilder()//此字段的值是用来指定本推送要推送的apns环境,false表示开发,true表示生产;对android和自定义消息无意义
.setApnsProduction(false)//此字段是给开发者自己给推送编号,方便推送者分辨推送记录
.setSendno(1)//此字段的值是用来指定本推送的离线保存时长,如果不传此字段则默认保存一天,最多指定保留十天,单位为秒
.setTimeToLive(86400)
.build())
.build();
}
}