IOS本地,APNS遠程推送(具體過程),iosapns推送

來源:互聯網
上載者:User

IOS本地,APNS遠程推送(具體過程),iosapns推送

添加本地推送

///本地添加  

  1. -(void)addLocalPushNotification:(UIButton*)sender;  
  2. {  
  3.       
  4.       
  5.     NSLog(@"%s",__FUNCTION__);  
  6.     UILocalNotification* localNotification=[[UILocalNotification alloc]init];  
  7.       
  8.     if (localNotification) {  
  9.         //設定時間當前加20秒  
  10.         NSDate* pushDate=[NSDate dateWithTimeIntervalSinceNow:20];  
  11.         /*推送時區設定:從網上搜到 
  12.         timeZone是UILocalNotification激發時間是否根據時區改變而改變,如果設定為nil的話,那麼UILocalNotification將在一段時候後被激發,而不是某一個確切時間被激發。*/  
  13.         localNotification.timeZone=[NSTimeZone defaultTimeZone];  
  14.         ///推送時間設定  
  15.         localNotification.fireDate=pushDate;  
  16.         //時間間隔,若不設定將只會推送1次  
  17.         localNotification.repeatInterval=kCFCalendarUnitDay;  
  18.         //推送時的聲音,(若不設定的話系統推送時會無聲音)  
  19.         localNotification.soundName=UILocalNotificationDefaultSoundName;  
  20.         //推送的文字資訊(若不設定,推送中心中不顯示文字,有聲音提示前提是設定有聲音)  
  21.         localNotification.alertBody=@"Hello world";  
  22.         //推送時小表徵圖的設定,PS:這個東西不知道還有啥用  
  23.         localNotification.alertLaunchImage=[[NSBundle mainBundle]pathForResource:@"3" ofType:@"jpg"];  
  24.           
  25.         ///這個東西,到時用於定位是哪個notification,以便取消用  
  26.         NSDictionary* infoDic=[NSDictionary dictionaryWithObject:@"name" forKey:@"key"];  
  27.         localNotification.userInfo=infoDic;  
  28.           
  29.         //講推送設定以及資訊加入  
  30.         UIApplication* app=[UIApplication sharedApplication];  
  31.         BOOL status=YES;  
  32.         for (UILocalNotification* notification in app.scheduledLocalNotifications) {  
  33.             if ([notification.userInfo objectForKey:@"key"]) {  
  34.                 status=NO;  
  35.             }  
  36.         }  
  37.           
  38.         if (status) {  
  39.             //加入推送(只能加入一次)  
  40.             [app scheduleLocalNotification:localNotification];  
  41.         }  
  42.           
  43.   
  44.           
  45.         NSLog(@"%@",app.scheduledLocalNotifications);  
  46.     }  
  47. }  

 

 

取消本地推送 
  1. ///本地移除  
  2. -(void)removeLocalPushNotification:(UIButton*)sender  
  3. {  
  4.     NSLog(@"%s",__FUNCTION__);  
  5.     UIApplication* app=[UIApplication sharedApplication];  
  6.     //擷取當前應用所有的通知  
  7.     NSArray* localNotifications=[app scheduledLocalNotifications];  
  8.   
  9.     if (localNotifications) {  
  10.           
  11.         for (UILocalNotification* notification in localNotifications) {  
  12.   
  13.             NSDictionary* dic=notification.userInfo;  
  14.               
  15.             if (dic) {  
  16.                 NSString* key=[dic objectForKey:@"key"];  
  17.                 if ([key isEqualToString:@"name"]) {  
  18.                     //取消推送 (指定一個取消)  
  19.                     [app cancelLocalNotification:notification];  
  20.                       
  21.                     break;  
  22.                 }  
  23.             }  
  24.   
  25.         }  
  26.     }  
  27.     //取消當前應用所有的推送  
  28.     //[app cancelAllLocalNotifications];  
  29.       
  30.       
  31. }  


 

 

 

 

 

遠程推送

 

當服務端遠程向APNS推送至一台離線的裝置時,蘋果伺服器Qos組件會自動保留一份最新的通知,等裝置上線後,Qos將把推送發送到目標裝置上

 

用戶端需要注意的

 bundle ID與App Id一致

裝置Token能正常擷取

若為沙箱測試,認證得使用developer的

 

單裝置

如所示:我們的服務端將需要推送的相關資訊提交到APNS(Apple Push Notification Service),由APNS在Push服務IOS裝置列表中找到對應的裝置,並將資訊推到終端上,終端上再推到用戶端APP上

多裝置

 

 

 

流程大概是這樣的

1.產生CertificateSigningRequest.certSigningRequest檔案

2.將CertificateSigningRequest.certSigningRequest上傳進developer,匯出.cer檔案

3.利用CSR匯出P12檔案

4.需要準備下裝置token值(無空格)

5.使用OpenSSL合成伺服器所使用的推送認證

 

1.開啟鑰匙串,在右上方選擇(鑰匙串訪問->認證助理->從憑證授權單位請求認證)

 

產生 CertificateSigningRequest.certSigningRequest

 

以下資訊填寫號後,儲存到對應位置

 

 

2.進入developer.apple.com中 上傳CertificateSigningRequest.certSigningRequest並儲存cer檔案

(1)

(2)選擇類型為 推送服務--沙箱測試用

 

(3)選中對應的APP ID,別忘了,項目設定檔中的Bundle ID與其一致

(4)選擇儲存路徑

(5)選擇上傳檔案 CertificateSigningRequest.certSigningRequest

(6)儲存cer檔案,並雙擊添加進鑰匙串

 

(7)建立一個Provisioning Profiles

 

 

選中與前面一致的 App Id

 

選中剛才建立的certificates

 

選擇可調試裝置

 

儲存provisioning檔案,並將其加入裝置中

 

通過OPENSSL檔案合并

1.在鑰匙串->認證 找到剛才所添加進去的認證 右鍵匯出p12

2.進入終端 ,將aps_development.cer轉成PushChatCert.pem(openssl x509 -in aps_development.cer -inform der  -out PushChatCert.pem)

3.openssl pkcs12 -nocerts -out PushChatKey.pem -in Push.p12  產生p12私密金鑰 .pem檔案(需設定密碼,服務端推送時要用)

4.利用PushChatCert.pem和新產生的PushChatKey.pem合成一個新的p12檔案(這個p12是提供給伺服器推送用的)(

openssl pkcs12 -export -in PushChatCert.pem -inkey PushChatKey.pem -certfile CertificateSigningRequest.certSigningRequest -name "aps_developer_identity" -out aps_developer_identity.p12

 

合成PHP所用的PEM檔案

 


 

 

 

 

 

代碼實現如下

 

註冊推播通知

 

[cpp] view plaincopy 
  1. [[UIApplication sharedApplication] registerForRemoteNotificationTypes:  
  2. (UIRemoteNotificationTypeAlert|  
  3.  UIRemoteNotificationTypeBadge|  
  4.  UIRemoteNotificationTypeSound)];  


 

在AppDelegate中加入以下幾個代理方法

 

[cpp] view plaincopy 
  1. ///Token值成功擷取的時候走的是這個方法(Token值不能帶空格)  
  2. -(void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken  
  3. {  
  4.   
  5.     NSLog(@"%@",deviceToken);  
  6.   
  7. }  
  8. ///Token值擷取失敗的時候走的是這個方法  
  9. -(void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error  
  10. {  
  11.   
  12.     NSLog(@"%@",error);  
  13. }  
  14. ///應用程式處在開啟狀態,且伺服器有推送訊息過來時,以及通過推送開啟應用程式,走的是這個方法  
  15. -(void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo  
  16. {  
  17.     for (id key in userInfo) {  
  18.         NSLog(@"%@:%@",key, [userInfo objectForKey:key]);  
  19.     }  
  20.     ///Icon推送數量設為0  
  21. //    application.applicationIconBadgeNumber=0;  
  22. }  

應用程式不處在後台,且通過推播通知開啟的時候,如果需要推送下來相關的資訊可以在

 

[cpp] view plaincopy 
  1. - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions  

方法中加入

 

 

[cpp] view plaincopy 
  1. ///應用程式不處在後台,並且是通過推送開啟應用的時候  
  2. if (launchOptions) {  
  3.     ///擷取到推送相關的資訊  
  4.     NSDictionary *userInfo = [launchOptions objectForKey:UIApplicationLaunchOptionsRemoteNotificationKey];  
  5. }  

 

 


 

服務端PHP推送代碼

 

[cpp] view plaincopy 
  1. <?php  
  2.     $deviceToken= 'ba6d5106503c8e62e68b5df1b36c3b58ced1588c6dabe0fc9e6828961aeb12d6'; //沒有空格  
  3.     $body = array("aps" => array("alert" => 'helloHui',"badge" => 2,"sound"=>'default'));  //推送方式,包含內容和聲音  
  4.     $ctx = stream_context_create();  
  5.     //如果在Windows的伺服器上,尋找pem路徑會有問題,路徑修改成這樣的方法:  
  6.     //$pem = dirname(__FILE__) . '/' . 'apns-dev.pem';  
  7.     //linux 的伺服器直接寫pem的路徑即可  
  8.     stream_context_set_option($ctx,"ssl","local_cert","26ck.pem");  
  9.     $pass = "123123";  
  10.     stream_context_set_option($ctx, 'ssl', 'passphrase', $pass);  
  11.     //此處有兩個伺服器需要選擇,如果是開發測試用,選擇第二名sandbox的伺服器並使用Dev的pem認證,如果是正是發布,使用Product的pem並選用正式的伺服器  
  12. //    $fp = stream_socket_client("ssl://gateway.push.apple.com:2195", $err, $errstr, 60, STREAM_CLIENT_CONNECT, $ctx);  
  13.     $fp = stream_socket_client("ssl://gateway.sandbox.push.apple.com:2195", $err, $errstr, 60, STREAM_CLIENT_CONNECT, $ctx);  
  14.     if (!$fp) {  
  15.         echo "Failed to connect $err $errstrn";  
  16.         return;  
  17.     }  
  18.     print "Connection OK\n";  
  19.     $payload = json_encode($body);  
  20.     $msg = chr(0) . pack("n",32) . pack("H*", str_replace(' ', '', $deviceToken)) . pack("n",strlen($payload)) . $payload;  
  21.     echo "sending message :" . $payload ."\n";  
  22.     fwrite($fp, $msg);  
  23.     fclose($fp);?>  
[php] view plaincopy 
  1. <pre></pre>  
  2. <pre></pre>  
  3. <pre></pre>  
  4. <pre></pre>  
  5. <pre></pre>  
  6. <pre></pre>  
  7.       
  8.         <div style="padding-top:20px">           
  9.             <p style="font-size:12px;">著作權聲明:本文為博主原創文章,未經博主允許不得轉載。</p>  
  10.         </div>  
 
  • 上一篇SpriteKit-粒子效果-SKEmitterNode
  • 下一篇將字串中各單詞首字母轉化成大寫,使用回呼函數實現[函數指標]
 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.