1. 添加依赖
//jpush
compile group: 'cn.jpush.api', name: 'jpush-client', version: '3.3.4'
2. 注册极光用户
//APP端注册极光Id,jpushId为每个用户在各个设备的唯一标识
public void registeAuroral(String jpushId) {
JPushInterface.setAlias(LaunchActivity.this, jpushId, new TagAliasCallback() {
@Override
public void gotResult(final int code, String s, Set set) {
LKLogUtil.e("极光别名设置==失败errorCode = " + code);
switch (code) {
case 0:
LKLogUtil.e("极光别名设置===成功");
break;
case 6002:
LKLogUtil.e("极光别名设置===超时");
mHandler.postDelayed(new Runnable() {
@Override
public void run() {
JPushInterface.resumePush(LaunchActivity.this);
setAlias(jpushId);
}
}, 1000 * 60);
break;
case 6012:
LKLogUtil.e("极光别名设置==失败errorCode = " + code);
mHandler.postDelayed(new Runnable() {
@Override
public void run() {
JPushInterface.resumePush(LaunchActivity.this);
setAlias(jpushId);
LKLogUtil.e("极光别名设置==失败errorCode = " + code);
}
}, 1000 * 60);
break;
default:
LKLogUtil.e("极光别名设置==失败errorCode = " + code);
break;
}
}
});
}
3. 后台代码推送极光
//******************************************************JPushUtil.class
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.audience.AudienceTarget;
import cn.jpush.api.push.model.notification.AndroidNotification;
import cn.jpush.api.push.model.notification.IosNotification;
import cn.jpush.api.push.model.notification.Notification;
import com.alibaba.fastjson.JSON;
import net.sf.jsqlparser.statement.alter.Alter;
import java.util.Map;
/**
* @author syg
* Created by lenovo on 2017/02/24.
*/
public class JPushUtil {
/**
* 发送给所有用户
* @param notificationTitle
* @param1 avatar
* @param1 nick
* @param1 imTag jumpType
* @return
*/
public static PushPayload buildPushObject_android_and_ios(String notificationTitle, String title, Map map, String[]alias, boolean isApnsProduction) {
return PushPayload.newBuilder()
.setPlatform(Platform.android_ios())
.setAudience(Audience.alias(alias))
.setNotification(Notification.newBuilder()
.setAlert(notificationTitle)
.addPlatformNotification(AndroidNotification.newBuilder()
.setAlert(notificationTitle)
//.setTitle(notification_title)
//此字段为透传字段,不会显示在通知栏。用户可以通过此字段来做一些定制需求,如特定的key传要指定跳转的页面(value)
//.setTitle(title)
.addExtras(map)
.build()
)
.addPlatformNotification(IosNotification.newBuilder()
//传一个IosAlert对象,指定apns title、title、subtitle等
.setAlert(notificationTitle)
//直接传alert
//此项是指定此推送的badge自动加1
//.incrBadge(1)
.disableBadge()
//此字段的值default表示系统默认声音;传sound.caf表示此推送以项目里面打包的sound.caf声音来提醒,
// 如果系统没有此音频则以系统默认声音提醒;此字段如果传空字符串,iOS9及以上的系统是无声音提醒,以下的系统是默认声音
.setSound("default")
//此字段为透传字段,不会显示在通知栏。用户可以通过此字段来做一些定制需求,如特定的key传要指定跳转的页面(value)
// .addExtra("iosNotification extras key",extrasparam)
.addExtras(map)
//此项说明此推送是一个background推送,想了解background看:http://docs.jpush.io/client/ios_tutorials/#ios-7-background-remote-notification
// .setContentAvailable(true)
.build()
)
.build()
)
.setOptions(Options.newBuilder()
//此字段的值是用来指定本推送要推送的apns环境,false表示开发,true表示生产;对android和自定义消息无意义
.setApnsProduction(isApnsProduction)
//此字段是给开发者自己给推送编号,方便推送者分辨推送记录
.setSendno(1)
//此字段的值是用来指定本推送的离线保存时长,如果不传此字段则默认保存一天,最多指定保留十天,单位为秒
.setTimeToLive(600)
.build()
)
.build();
}
/**
* 透传消息
* @param msgContent 透传消息内容
* @param map 透传消息附加参数
* @param alias 透传消息发送人
* @return
*/
public static PushPayload buildPushObject_ios_audienceMore_messageWithExtras(String msgContent, Map map, String[] alias) {
return PushPayload.newBuilder()
.setPlatform(Platform.android_ios())
.setAudience(Audience.alias(alias))
.setMessage(Message.newBuilder()
.setMsgContent(msgContent)
.addExtras(map)
.build())
.build();
}
/**
* 发送给所有指定设备
* @param notificationTitle
* @param
* @param
* @param
* @return
*/
public static PushPayload buildPushObjectAllTarget(String notificationTitle, Map map, String title, boolean isApnsProduction) {
return PushPayload.newBuilder()
.setPlatform(Platform.android_ios())
.setAudience(Audience.all())
.setNotification(Notification.newBuilder()
.setAlert(notificationTitle)
.addPlatformNotification(AndroidNotification.newBuilder()
.setAlert(notificationTitle)
//.setTitle(notification_title)
//此字段为透传字段,不会显示在通知栏。用户可以通过此字段来做一些定制需求,如特定的key传要指定跳转的页面(value)
.setTitle(title)
.addExtras(map)
.build()
)
.addPlatformNotification(IosNotification.newBuilder()
//传一个IosAlert对象,指定apns title、title、subtitle等
.setAlert(notificationTitle)
//直接传alert
//此项是指定此推送的badge自动加1
//.incrBadge(1)
//此字段的值default表示系统默认声音;传sound.caf表示此推送以项目里面打包的sound.caf声音来提醒,
// 如果系统没有此音频则以系统默认声音提醒;此字段如果传空字符串,iOS9及以上的系统是无声音提醒,以下的系统是默认声音
.setSound("default")
//此字段为透传字段,不会显示在通知栏。用户可以通过此字段来做一些定制需求,如特定的key传要指定跳转的页面(value)
// .addExtra("iosNotification extras key",extrasparam)
.addExtras(map)
//此项说明此推送是一个background推送,想了解background看:http://docs.jpush.io/client/ios_tutorials/#ios-7-background-remote-notification
// .setContentAvailable(true)
.build()
)
.build()
)
//自定义消息
.setMessage(Message.newBuilder()
.setMsgContent(notificationTitle)
.setTitle(title)
.addExtras(map)
.build())
.setOptions(Options.newBuilder()
//此字段的值是用来指定本推送要推送的apns环境,false表示开发,true表示生产;对android和自定义消息无意义
.setApnsProduction(isApnsProduction)
//此字段是给开发者自己给推送编号,方便推送者分辨推送记录
.setSendno(1)
//此字段的值是用来指定本推送的离线保存时长,如果不传此字段则默认保存一天,最多指定保留十天,单位为秒
.setTimeToLive(600)
.build()
)
.build();
}
/**
* 根据别名推送至android
* @param notificationTitle
* @param alias
* @return
*/
public static PushPayload buildPushObjectAndroidAllAlertWithTitle(String notificationTitle, String title, String[] alias, Map map, boolean isApnsProduction) {
return PushPayload.newBuilder()
//指定要推送的平台,all代表当前应用配置了的所有平台,也可以传android等具体平台
.setPlatform(Platform.android())
//指定推送的接收对象,all代表所有人,也可以指定已经设置成功的tag或alias或该应应用客户端调用接口获取到的registration id
.setAudience(Audience.alias(alias))
//jpush的通知,android的由jpush直接下发,iOS的由apns服务器下发,Winphone的由mpns下发
.setNotification(Notification.newBuilder()
//指定当前推送的android通知
.addPlatformNotification(AndroidNotification.newBuilder()
.setAlert(notificationTitle)
.setTitle(title)//此字段为app名称
.addExtras(map)
.build())
.build()
)
.setOptions(Options.newBuilder()
//此字段的值是用来指定本推送要推送的apns环境,false表示开发,true表示生产;对android和自定义消息无意义
.setApnsProduction(isApnsProduction)
//此字段是给开发者自己给推送编号,方便推送者分辨推送记录
.setSendno(1)
//此字段的值是用来指定本推送的离线保存时长,如果不传此字段则默认保存一天,最多指定保留十天,单位为秒
.setTimeToLive(600)
.build())
.build();
}
/**
* 根据别名推送至ios
* @param notificationTitle
* @param alias
* @return
*/
public static PushPayload buildPushObjectIosAllAlertWithTitle(String notificationTitle, String[] alias,
Map map, boolean isApnsProduction) {
return PushPayload.newBuilder()
//指定要推送的平台,all代表当前应用配置了的所有平台,也可以传android等具体平台
.setPlatform(Platform.ios())
//指定推送的接收对象,all代表所有人,也可以指定已经设置成功的tag或alias或该应应用客户端调用接口获取到的registration id
.setAudience(Audience.alias(alias))
//jpush的通知,android的由jpush直接下发,iOS的由apns服务器下发,Winphone的由mpns下发
.setNotification(Notification.newBuilder()
//指定当前推送的android通知
.addPlatformNotification(IosNotification.newBuilder()
//传一个IosAlert对象,指定apns title、title、subtitle等
.setAlert(notificationTitle)
.addExtras(map)
//直接传alert
//此项是指定此推送的badge自动加1
//.incrBadge(1)
//此字段的值default表示系统默认声音;传sound.caf表示此推送以项目里面打包的sound.caf声音来提醒,
// 如果系统没有此音频则以系统默认声音提醒;此字段如果传空字符串,iOS9及以上的系统是无声音提醒,以下的系统是默认声音
.setSound("default")
//此项说明此推送是一个background推送,想了解background看:http://docs.jpush.io/client/ios_tutorials/#ios-7-background-remote-notification
// .setContentAvailable(true)
.build())
.build()
)
.setOptions(Options.newBuilder()
//此字段的值是用来指定本推送要推送的apns环境,false表示开发,true表示生产;对android和自定义消息无意义
.setApnsProduction(isApnsProduction)
//此字段的值是用来指定本推送的离线保存时长,如果不传此字段则默认保存一天,最多指定保留十天,单位为秒
.setTimeToLive(600)
.build())
.build();
}
/**
* 根据别名推送至指定用户
* @param registrationId
* @param notificationTitle
* @param
* @param
* @param
* @return
*/
public static PushPayload buildPushObjectAllRegistrationIdAlertWithTitle(String registrationId,
String notificationTitle, String title,
Map map, boolean isApnsProduction) {
//创建一个IosAlert对象,可指定APNs的alert、title等字段
return PushPayload.newBuilder()
//指定要推送的平台,all代表当前应用配置了的所有平台,也可以传android等具体平台
.setPlatform(Platform.all())
//指定推送的接收对象,all代表所有人,也可以指定已经设置成功的tag或alias或该应应用客户端调用接口获取到的registration id
.setAudience(Audience.alias(registrationId))
//jpush的通知,android的由jpush直接下发,iOS的由apns服务器下发,Winphone的由mpns下发
.setNotification(Notification.newBuilder()
//指定当前推送的android通知
.addPlatformNotification(AndroidNotification.newBuilder()
.setAlert(notificationTitle)
.setTitle(title)
.addExtras(map)
.build())
//指定当前推送的iOS通知
.addPlatformNotification(IosNotification.newBuilder()
//传一个IosAlert对象,指定apns title、title、subtitle等
.setAlert(notificationTitle)
.addExtras(map)
//.incrBadge(1)
.setSound("default")
.build())
.build())
.setOptions(Options.newBuilder()
//此字段的值是用来指定本推送要推送的apns环境,false表示开发,true表示生产;对android和自定义消息无意义
.setApnsProduction(isApnsProduction)
//此字段是给开发者自己给推送编号,方便推送者分辨推送记录
.setSendno(1)
//此字段的值是用来指定本推送的离线保存时长,如果不传此字段则默认保存一天,最多指定保留十天;
.setTimeToLive(600)
.build())
.build();
}
}
//********************************************* AuroraPusher.class
@Component
public class AuroraPusher {
public final static Logger logger = LogManager.getLogger(AuroraPusher.class);
@Value("${jpush.masterSecret}")
private String masterSecret;
@Value("${jpush.appKey}")
private String appKey;
@Value("${jpush.isApnsProduction}")
private boolean isApnsProduction;
/** 第三方规定推送接收对象数量 */
private final int aliaSize = 38;
/** 推送客户端 */
private JPushClient jPushClient;
/** 获取推送客户端 */
public JPushClient getjPushClient() {
if(jPushClient == null){
jPushClient = new JPushClient (masterSecret, appKey);
}
return jPushClient;
}
/**
* 发送推送
* @param payload 推送内容
* @return
*/
private boolean push(PushPayload payload){
try {
PushResult pushResult = this.getjPushClient().sendPush(payload) ;
logger.debug("调用推送方法响应结果为:" + pushResult != null ? pushResult.toString() : "推送响应内容为空");
final int code = 200;
//存在有未登录用户错误码
final int error_code = 1011;
if(pushResult == null || code != pushResult.getResponseCode()){
if(error_code == pushResult.getResponseCode()){
throw new SendMessageFailureException(error_code, "选择用户中包含存未在伯通APP登录激活的用户");
}
throw new SendMessageFailureException("推送消息时,第三方响应错误,错误原因为:" + pushResult.error.getMessage());
}
} catch (APIConnectionException e) {
logger.error("推送消息时,连接第三方异常, 异常原因:" + e.getMessage(), e);
throw new SendMessageFailureException("推送消息时,连接第三方异常");
} catch (APIRequestException e) {
logger.error("推送消息时,请求第三方异常, 异常原因:" + e.getMessage(), e);
throw new SendMessageFailureException("推送消息时,请求第三方异常");
}
return true;
}
/**
* 推送至所有设备
* @param notificationTitle
* @param title
* @param map
* @return
*/
public boolean pushAllTarget(String notificationTitle, String title, Map map) {
PushPayload payload = JPushUtil.buildPushObjectAllTarget(notificationTitle, map, title, isApnsProduction);
return this.push(payload);
}
/**
* 推送至所有设备
* @param notificationTitle
* @param map
* @param title
* @param alias
* @return
*/
public boolean pushAllTargetByUser(String notificationTitle, String title, Map map, String[] alias) {
PushPayload payload;
List> aliaList = splitArraySpecifySizeList(alias, aliaSize);
for(List itemList : aliaList){
payload = JPushUtil.buildPushObject_android_and_ios(notificationTitle, title, map, itemList.toArray(new String[]{}), isApnsProduction);
this.push(payload);
}
return true;
}
/**
* 透传消息
* @param msgContent 透传消息内容
* @param map 附加信息
* @param alias 接收人
* @return
*/
public boolean buildPushObjectAudienceMoreMessageWithExtras(String msgContent, Map map, String[] alias){
PushPayload payload;
List> aliaList = splitArraySpecifySizeList(alias, aliaSize);
for(List itemList : aliaList){
payload = JPushUtil.buildPushObject_ios_audienceMore_messageWithExtras(msgContent, map, itemList.toArray(new String[]{}));
this.push(payload);
}
return true;
}
/**
* 根据ilias推送至android
* @param msg
* @param title
* @param alias
* @param map
* @return
*/
public boolean sendAllAndroid(String msg, String title, String[] alias, Map map) {
PushPayload payload;
List> aliaList = splitArraySpecifySizeList(alias, aliaSize);
for(List itemList : aliaList){
payload = JPushUtil.buildPushObjectAndroidAllAlertWithTitle(msg, title, itemList.toArray(new String[]{}), map, isApnsProduction);;
this.push(payload);
}
return true;
}
/**
* 根据ilias推送至ios
* @param msg
* @param alias
* @param map
* @return
*/
public boolean sendAllIos(String msg, String[] alias, Map map) {
PushPayload payload;
List> aliaList = splitArraySpecifySizeList(alias, aliaSize);
for(List itemList : aliaList){
payload = JPushUtil.buildPushObjectIosAllAlertWithTitle(msg, itemList.toArray(new String[]{}), map, isApnsProduction);
this.push(payload);
}
return true;
}
/**
* 根据alias推送至指定设备
* @param registrationId
* @param notificationTitle
* @param title
* @param map
* @return
*/
public boolean sendByAlias(String registrationId, String notificationTitle, String title, Map map) {
PushPayload payload;
String[] alias = registrationId.split(",");
if(alias.length < aliaSize){
payload = JPushUtil.buildPushObjectAllRegistrationIdAlertWithTitle(registrationId, title, notificationTitle, map, isApnsProduction);
this.push(payload);
} else {
List> list = splitArraySpecifySizeList(alias, aliaSize);
for(List temp : list){
payload = JPushUtil.buildPushObjectAllRegistrationIdAlertWithTitle(String.join(",", temp), title, notificationTitle, map, isApnsProduction);
this.push(payload);
}
}
return true;
}
/**
* 拆分接收对象为指定数量的数组对象集合
* @param alias 推送接收对象
* @param size 指定数量
* @return
*/
private List> splitArraySpecifySizeList(String[] alias, final int size){
if(ArrayUtils.isEmpty(alias)){
return null;
}
return ListUtils.getAllowList(Arrays.asList(alias), size);
}
}