凡是要从事或正在从事苹果的IOS开发的朋友,必定听说或者用过push技术。实际上玩过或现在正在用iphone,ipad系列终端的朋友,也必定会感受到推送技术带来的便捷。比如说,我们只要iphone在开机的情况下,就会定时或不定时收到一些自动弹出的消息,如天气预报,网易新闻之类的信息。当然android手机,同样也可以实现push技术。哈哈,下面是阿堂测试的在我的的iphone手机截屏的一张图片,想必朋友们看到后,就会有一种感官上的认识了!事实上,实现push技术的过程还是挺麻烦的,除了必要的原理知识掌握外,它的整个操作流程非常多,还是需要必须非常细心的,每一个步骤都不能出错,可能有很多人要测试push技术时会花较长时间后才真正测试成功或掌握!这 一点阿堂是深有体会的!
由于公司业务的发展需要,阿堂学习和使用ios已经有一月左右了,还是颇有认识的。只是由于阿堂接触的时间也不长,从接触oc和iphone的一些组件的用法开始,就已经渐渐迷上了ios的开发,不能不说apple公司的伟大,也怪不得iphone,ipad现在社会上如此之火了,的确是手机中的精品啊。。
Push的原理:
Push 的工作机制可以简单的概括为下图
图中,Provider是指某个iPhone软件的Push服务器,这篇文章我将使用java作为Provider。
APNS 是Apple Push Notification Service(Apple Push服务器)的缩写,是苹果的服务器。
上图可以分为三个阶段。
第一阶段:java应用程序把要发送的消息、目的iPhone的标识打包,发给APNS。
第二阶段:APNS在自身的已注册Push服务的iPhone列表中,查找有相应标识的iPhone,并把消息发到iPhone。
第三阶段:iPhone把发来的消息传递给相应的应用程序, 并且按照设定弹出Push通知
。
从上图我们可以看到。
1、首先是应用程序注册消息推送。
2、 IOS跟APNS Server要deviceToken。应用程序接受deviceToken。
3、应用程序将deviceToken发送给PUSH服务端程序。
4、 服务端程序向APNS服务发送消息。
5、APNS服务将消息发送给iPhone应用程序。
无论是iPhone客户端跟APNS,还是Provider和APNS都需要通过证书进行连接的。下面我介绍一下几种用到的证书。
几种证书:
一、*.certSigningRequest文件
1、生成Certificate Signing Request (CSR):
2、填写你的邮箱和Common Name,这里填写为PushChat。选择保存到硬盘。
这样就在本地生成了一个PushChat.certSigningRequest文件。
二、生成*.p12文件
1、导出密钥,并输入你的密码。
输入你的密码:
这样就生成了一个PushChatKey.p12文件。
三、新建一个App ID 和SSL certificate文件
1、用你的付过费的apple帐号登录到iOS Provisioning Portal。新建一个App ID。
Description:中输入PushChat
Bundle Seed ID:默认选择Generate New
Bundle Identifier:输入com.mysoft.PushChat
点击提交
这样就会生成下面这条记录:
点击配置:
出现下面界面,点击继续:
这里我们选择前面生成好的PushChat.certSigningRequest文件,点击生成。
正在生成
生成完毕,我们把它下载下来。命名为aps_developer_identity.cer。
点击完成,你会发现状态变成Enabled。
到现在为止,我们已经生成了3个文件。
1、PushChat.certSigningRequest
2、PushChatKey.p12
3、aps_developer_identity.cer
现在我们创建一个简单的iPhone应用程序。
1、打开Xcode,选择创建一个View-based Application。命名如下图:
2、在PushChatAppDelegate中的didFinishLaunchingWithOptions方法中加入下面代码:
通过registerForRemoteNotificationTypes方法,告诉应用程序,能接受push来的通知。
3、在xcode中运行,会弹出下面的提示框:
选择OK。表示此应用程序开启消息通知服务。
在 PushChatAppDelegate.m代码中添加下面方法获取deviceToken :
发送通知的JAVA应用程序出来需要知道deviceToken之外,还需要一个与APNS连接的证书。
这个证书可以通过我们前面生成的两个文件中得到。
使用OpenSSL生成.net和APNS通信的证书文件。
1、将aps_developer_identity.cer转换成 aps_developer_identity.pem格式。
openssl x509 -in aps_developer_identity.cer -inform DER -out aps_developer_identity.pem -outform PEM
2、将p12格式的私钥转换成pem,需要设置4次密码,这里密码都设置为:abc123。
openssl pkcs12 -nocerts -out PushChat_Noenc.pem -in PushChat.p12
3、用certificate和the key 创建PKCS#12格式的文件。
openssl pkcs12 -export -in aps_developer_identity.pem -inkey PushChat_Noenc.pem -certfile PushChat.certSigningRequest -name "aps_developer_identity" -out aps_developer_identity.p12
这样我们就得到了在.net应用程序中使用的证书文件:aps_developer_identity.p12。
在JAVA应用程序中发送通知。
阿堂在java中测试推送通知的代码如下
String deviceToken ="b329a641f4daabd7cbb9170f55821ee80559ea8b694c23797406785a33484ec8";
PayLoad payLoad = new PayLoad();
payLoad.addAlert("钱宝支付\n网络时空(阿堂)测试APPLE的PUSH功能成功啦!\n想学习不?快点联系网络时空学习IOS开发吧!\n联系方式:http://blog.sina.com.cn/heyitang");//push的内容
payLoad.addBadge(1);//图标小红圈的数值
payLoad.addSound("default");//铃音
PushNotificationManager pushManager = PushNotificationManager.getInstance();
pushManager.addDevice("iPhone",deviceToken);
//Connect to APNs
/
String host= "gateway.sandbox.push.apple.com";
int port = 2195;
String certificatePath= "e:\\aps_developer_identity.p12";//导出的证书
String certificatePassword= "abcd123456";//此处注意导出的证书密码不能为空因为空密码会报错
pushManager.initializeConnection(host, port, certificatePath, certificatePassword, SSLConnectionHelper.KEYSTORE_TYPE_PKCS12);
//Send Push
Device client = pushManager.getDevice("iPhone");
pushManager.sendNotification(client, payLoad);
pushManager.stopConnection();
pushManager.removeDevice("iPhone");
System.out.println("OK");
这样就OK了。
阿堂在iphone上的截屏照片如下: