一、首先先简单的介绍一下什么是极光推送
①为什么需要推送:为了解决数据同步的问题,在手机平台上,常用的方法有2种。一种是定时去服务器上查询数据,也叫polling,还有一种手机跟服务器之间维护一个 tcp 长连接,当服务器有数据时,实时推送到客户端,也就是我们说的 push。由于做推送在移动网络下维持长连接有一定的技术难度,而且当用户量上去的时候,需要很多服务器来维持长连接,成本也是很大的。因此我们需要一个第三方的jar包来支持我们的推送服务。如果想了解更多内容可参看极光推送官方文档。
②极光推送的通俗解答:就是把需要推送的内容通过调用jpush的api的发送到极光推送的服务器上,极光推送的服务器根据我们推送过去的内容选择推送到具体的app。
二、源码
服务端代码:
安卓客户端代码:
安卓环境为:adt+sdk+eclipse
adt下载:
sdk下载:
所需jdk的环境安装就不一一叙述了。
注:代码可直接导入只需要改几个地方后面会阐述。首先教大家搭下安卓环境先保证代码能导入成功
三、操作步骤
① 安装插件
②安装sdk
此步骤完成后页面会切换到android的开发界面,页面会多两个东西
选择你要安装的一般选择tools里面的和android你所需要的版本,然后带你安装,我这里已经没有选,所以示灰色的。
注:关于安装很慢或者安装失败
有两种方法:
① 使用fq软件 我用的蓝灯
② 使用配置镜像服务器 如图:
③然后导入安卓工程(服务端的工程就不叙述怎么导入了)
在工程列表的空白处右键--选择import--然后操作如图
然后是运行安卓程序(最好是插上数据线--打开手机的usb调试--然后程序运行的时候回下到手机上)
具体的可以百度下。
四、极光推送的使用(肯定要到官网注册一个账号)
具体使用请百度,或者参照官网,下面是主要截图
appkey和master secret 后面会用到
五、修改android配置文件,将appkey改成你所添加的应用的appkey
六、服务端代码展示,代码均有注释就不一一解释了
只用的到这三个代码
appket和mastersecret 改成你在极光开发者服务添加的应用时所生产的字符串
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 }
view code
运行服务端代码后手机会受到如下通知:
其实就是服务端通过唯一识别的appkey和master secret将通知发送到极光服务器,服务器再转发至对应的app(上面app的配置文件里也配置了appkey)
具体操作就是这么多,可能不是很详细,但是操作步骤实在太多,就不一一截图了,这里只给大部分的具体方向。
以上就是关于极光推送jpush的实例讲解的详细内容。
