apns java 证书_APNS推送服务证书制作 图文详解教程(新)
iOS消息推送的工作機制可以簡單的用下圖來概括:
Provider是指某個iPhone軟件的Push服務器,APNS是Apple Push Notification Service的縮寫,是蘋果的服務器。
上圖可以分為三個階段:
第一階段:應用程序把要發(fā)送的消息、目的iPhone的標識打包,發(fā)給APNS。
第二階段:APNS在自身的已注冊Push服務的iPhone列表中,查找有相應標識的iPhone,并把消息發(fā)送到iPhone。
第三階段:iPhone把發(fā)來的消息傳遞給相應的應用程序,并且按照設定彈出Push通知。
從上圖我們可以看到:
1、應用程序注冊消息推送。
2、iOS從APNS Server獲取device token,應用程序接收device token。
3、應用程序將device token發(fā)送給PUSH服務端程序。
4、服務端程序向APNS服務發(fā)送消息。
5、APNS服務將消息發(fā)送給iPhone應用程序。
無論是iPhone客戶端和APNS,還是Provider和APNS,都需要通過證書進行連接。
下面我介紹一下幾種用到的證書。
一、CSR文件
1、生成Certificate Signing Request(CSR)
2、填寫你的郵箱和常用名稱,并選擇保存到硬盤。
點擊繼續(xù):
這樣就在本地生成了一個Push.certSigningRequest文件。
二、p12文件
1、導出密鑰。
2、輸入你的密碼。
這樣就生成了一個Push.p12文件。
三、SSL certificate文件
1、用你付過費的帳號登錄到iOS Provisioning Portal,并新建一個Explicit App ID,這個過程可以參考:我的另一篇博客
,這樣就會生成下面這條記錄:
2、點擊Edit:
3、勾選Push Notification -> Development SSL Certificate ->Creat Certifica...
4、點擊Continue
,
5、選擇前面生成好的Push.certSigningRequest文件,點擊Generate,出現如下所示的頁面:
6、點擊Download,并將文件命名為aps_development.cer。
7、點擊左側App IDs, 找到剛才新建的App ID, (testAppId) 你會發(fā)現狀態(tài)變成了Enabled:
注意:有的App ID的Apple Push Notification service列是灰色的,并且不允許使用Configure按鈕,這是因為APNS不支持帶通配符的App ID。
到現在為止,我們已經生成了三個文件:
1、Push.certSigningRequest
2、Push.p12
3、aps_development.cer
在項目的AppDelegate中的didFinishLaunchingWithOptions方法中加入下面的代碼:
-?(BOOL)application:(UIApplication?*)applicationdidFinishLaunchingWithOptions:(NSDictionary?*)launchOptions
{
//注冊APNS
[[UIApplicationsharedApplication]registerForRemoteNotificationTypes:(UIRemoteNotificationTypeAlert?|?UIRemoteNotificationTypeSound?|?UIRemoteNotificationTypeBadge)];
return?YES;
}
通過registerForRemoteNotificationTypes方法,告訴應用程序,能接受push來的通知。
在項目的AppDelegate中添加下面的方法來獲取deviceToken:
//APNS
-?(void)application:(UIApplication?*)appdidRegisterForRemoteNotificationsWithDeviceToken:(NSData?*)deviceToken?{
NSString?*token?=?[NSStringstringWithFormat:@"%@",deviceToken];
NSLog(@"My?token?is:%@",?token);
}
-?(void)application:(UIApplication?*)appdidFailToRegisterForRemoteNotificationsWithError:(NSError?*)error?{
NSString?*error_str?=?[NSStringstringWithFormat:?@"%@",error];
NSLog(@"Failed?to?get?token,?error:%@",?error_str);
}
-?(void)application:(UIApplication?*)applicationdidReceiveRemoteNotification:(NSDictionary?*)userInfo
{
}
運行程序可以獲取到device Token, 如圖,
獲取到的deviceToken,我們可以提交給后臺應用程序,
后臺程序實現有多種方式
一. PushMeBaby
1,將下載的aps_development.cer文件拷貝到PushMeBaby工程文件所在目錄,
2.打開工程,在工程文件上右擊 add file to "PushMeBaby",
3.run PushMeBaby? ,詢問是否允許訪問鑰匙串,點允許,
4,運行界面及日志如圖所示表示連接成功,
5, 將前面獲取到的 device Token 粘貼到輸入框中,點擊push,日志如下,0表示成功,111表示發(fā)送的數據的長度,
二. java, php
發(fā)送通知的后臺應用程序如果用php, java 實現,除了需要知道deviceToken之外,還需要一個與APNS連接的證書。
這個證書可以通過我們前面生成的兩個文件中得到。
1、將aps_development.cer轉換成aps_development.pem格式
openssl?x509?-in?aps_development.cer?-inform?DER?-out?aps_development.pem?-outform?PEM
2、將p12格式的私鑰轉換成pem
openssl?pkcs12?-nocerts?-out?Push_Noenc.pem?-in?Push.p12
3、創(chuàng)建p12文件
openssl?pkcs12?-export?-in?aps_development.pem?-inkey?Push_Noenc.pem?-certfile?Push.certSigningRequest?-name?"aps_development"?-out?aps_development.p12
這樣我們就得到了在.net或java等后臺應用程序中使用的證書文件:aps_development.p12
如果后臺應用是php的話,那么用以下方法來生成php后臺應用程序中使用的證書文件:ck.pem
6. Copy the file?apns-dev-cert.p12?to your server in the folder where you will put the rest of your PHP code.
7. Now run the following code on the server
openssl pkcs12 -clcerts -nokeys -out apns-dev-cert.pem -in apns-dev-cert.p12
openssl pkcs12 -nocerts -out apns-dev-key.pem -in apns-dev-key.p12
We are running everything from a server running?Ubuntu-9.04. Here we had to remove the passphrase, which can be done as follows
openssl rsa -in apns-dev-key.pem -out apns-dev-key-noenc.pem
Finally, combine the two to get your apns-dev.pem file
cat apns-dev-cert.pem apns-dev-key-noenc.pem > apns-dev.pem
總結
以上是生活随笔為你收集整理的apns java 证书_APNS推送服务证书制作 图文详解教程(新)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JS URL Parser
- 下一篇: 每天写出好代码的5个建议