標籤:des style blog class code java
Push的原理:Push 的工作機制可以簡單的概括為 圖中,Provider是指某個iPhone軟體的Push伺服器,這篇文章我將使用.net作為Provider。APNS 是Apple Push Notification Service(Apple Push伺服器)的縮寫,是蘋果的伺服器。可以分為三個階段。第一階段:Push伺服器應用程式把要發送的訊息、目的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都需要通過認證進行串連的。下面介紹一下所用到認證的製作。一、CSR檔案
1、產生Certificate Signing Request(CSR) 2、填寫你的郵箱和常用名稱,並選擇儲存到硬碟。 點擊繼續: 這樣就在本地產生了一個PushTest.certSigningRequest檔案。
二、SSL certificate檔案
1、用你付過費的帳號登入到iOS Provisioning Portal,並建立Certificates(已建立可省略),如: 點擊Submit 建立Certificate完畢。2、建立一個App ID點擊New App ID 輸入Description,Bundle Identifier,點擊Submit,建立App ID完畢。 找到建立的App ID 點擊右側的Configure: Development Push SSL Certificate ,與Production Push SSL Certificate 區別在於一個是用於開發的推送認證,一個是用於發布產品的推送認證。兩個認證擷取到的終端deviceToken是不一樣的,用兩個認證產生的P12認證用於JAVA後台串連APNS的伺服器位址也是不同的,Development Push SSL Certificate 對應已連線的服務器地址是:gateway.sandbox.push.apple.com。Production Push SSL Certificate 對應已連線的服務器地址是:gateway.push.apple.com。點擊Development Push SSL Certificate一行後的Configure: 點擊Continue: 選擇前面產生好的PushTest.certSigningRequest檔案,點擊Generate,出現如下所示的頁面: 點擊Continue: 點擊Download,下載產生的支援推送服務的認證(命名為:aps_development-6.cer)。
點擊Done,你會發現狀態變成了Enabled: 到現在為止,我們已經產生了兩個檔案:1、PushTest.certSigningRequest2、aps_development-6.cer(下載產生的支援推送服務的認證。)雙擊aps_development-6.cer註冊到你的鑰匙串中,這樣你的鑰匙串中就會有 三、準備profile認證,因為推送訊息只能在真機上測試,所以要建一個profile認證 點擊"new profile"為上面建立的APP ID建個profile ,成功之後下載pushtestdescDevprofile.mobileprovision 雙擊將其加入到xcode 的Provisioning Profiles 中。四、產生JAVA後台用於串連APNS的認證:開啟鑰匙串 選中Apple Development IOS Push Services:com.easecom.zhwgpushtestdesc,右鍵將其匯出。 匯出用於JAVA後台串連APNS的P12認證。 輸入p12 認證的密碼,本文中我用的是123456。記住這個密碼,JAVA後台使用p12認證的時候要用到。 輸入訪問鑰匙串的密碼:系統登陸密碼。 匯出PushTest.p12認證完畢。到現在為止,我們已經產生了四個檔案:1、PushTest.certSigningRequest2、aps_development-6.cer(下載產生的支援推送服務的認證。)3、pushtestdescDevprofile.mobileprovision
4、PushTest.p12至此IOS訊息推送(JAVA後台)認證全部製作完畢。下面開始上代碼:五、IOS端代碼:1、首先在項目的AppDelegate.m中加入以下兩個代理方法
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken { NSString *token = [NSString stringWithFormat:@"%@", deviceToken]; //擷取終端裝置標識,這個標識需要通過介面發送到伺服器端,伺服器端推送訊息到APNS時需要知道終端的標識,APNS通過註冊的終端標識找到終端裝置。 NSLog(@"My token is:%@", token); } - (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error { NSString *error_str = [NSString stringWithFormat: @"%@", error]; NSLog(@"Failed to get token, error:%@", error_str); }
2、在AppDelegate.m的(BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions方法中加入註冊訊息通知推送能力;加入當應用程式處於未啟動狀態時,判斷是否由遠程訊息通知觸發;加入清除訊息推播通知標記。
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions{ //判斷是否由遠程訊息通知觸發應用程式啟動 if ([launchOptions objectForKey:UIApplicationLaunchOptionsRemoteNotificationKey]!=nil) { //擷取應用程式訊息通知標記數(即小紅圈中的數字) int badge = [UIApplication sharedApplication].applicationIconBadgeNumber; if (badge>0) { //如果應用程式訊息通知標記數(即小紅圈中的數字)大於0,清除標記。 badge--; //清除標記。清除小紅圈中數字,小紅圈中數字為0,小紅圈才會消除。 [UIApplication sharedApplication].applicationIconBadgeNumber = badge; } } //訊息推送註冊 [[UIApplication sharedApplication] registerForRemoteNotificationTypes:UIRemoteNotificationTypeSound|UIRemoteNotificationTypeAlert|UIRemoteNotificationTypeBadge];}3、在項目AppDelegate.m中加入訊息接收處理代理方法。//處理收到的訊息推送- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo{ //在此處理接收到的訊息。 NSLog(@"Receive remote notification : %@",userInfo);}
六、JAVA後台代碼:
public static void main(String[] args) throws Exception { try { //從用戶端擷取的deviceToken,在此為了測試簡單,寫固定的一個測試裝置標識。 String deviceToken = "df779eda 73258894 5882ec78 3ac7b254 6ebc66fe fa295924 440d34ad 6505f8c4" System.out.println("Push Start deviceToken:" + deviceToken); //定義訊息模式 PayLoad payLoad = new PayLoad(); payLoad.addAlert("this is test!"); payLoad.addBadge(1);//訊息推送標記數,小紅圈中顯示的數字。 payLoad.addSound("default"); //註冊deviceToken PushNotificationManager pushManager = PushNotificationManager.getInstance(); pushManager.addDevice("iPhone", deviceToken); //串連APNS String host = "gateway.sandbox.push.apple.com"; //String host = "gateway.push.apple.com"; int port = 2195; String certificatePath = "c:/PushTest.p12";//前面產生的用於JAVA後台串連APNS服務的*.p12檔案位置 String certificatePassword = "123456";//p12檔案密碼。 pushManager.initializeConnection(host, port, certificatePath, certificatePassword, SSLConnectionHelper.KEYSTORE_TYPE_PKCS12); //發送推送 Device client = pushManager.getDevice("iPhone"); System.out.println("推送訊息: " + client.getToken()+"\n"+payLoad.toString() +" "); pushManager.sendNotification(client, payLoad); //停止串連APNS pushManager.stopConnection(); //刪除deviceToken pushManager.removeDevice("iPhone"); System.out.println("Push End"); } catch (Exception ex) { ex.printStackTrace(); }}}
至此大功告成,測試通過。以上在Iphone4,IPAD2裝置測試通過,Iphone3g,3gs需要打PushDoctor(推送醫生)補丁才能測試通過。