IOS 基於APNS訊息推送原理與實現(JAVA後台)--轉

來源:互聯網
上載者:User

標籤: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(推送醫生)補丁才能測試通過。
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.