IOS本地,APNS遠程推送(具體過程),iosapns推送
添加本地推送
///本地添加
- -(void)addLocalPushNotification:(UIButton*)sender;
- {
-
-
- NSLog(@"%s",__FUNCTION__);
- UILocalNotification* localNotification=[[UILocalNotification alloc]init];
-
- if (localNotification) {
- //設定時間當前加20秒
- NSDate* pushDate=[NSDate dateWithTimeIntervalSinceNow:20];
- /*推送時區設定:從網上搜到
- timeZone是UILocalNotification激發時間是否根據時區改變而改變,如果設定為nil的話,那麼UILocalNotification將在一段時候後被激發,而不是某一個確切時間被激發。*/
- localNotification.timeZone=[NSTimeZone defaultTimeZone];
- ///推送時間設定
- localNotification.fireDate=pushDate;
- //時間間隔,若不設定將只會推送1次
- localNotification.repeatInterval=kCFCalendarUnitDay;
- //推送時的聲音,(若不設定的話系統推送時會無聲音)
- localNotification.soundName=UILocalNotificationDefaultSoundName;
- //推送的文字資訊(若不設定,推送中心中不顯示文字,有聲音提示前提是設定有聲音)
- localNotification.alertBody=@"Hello world";
- //推送時小表徵圖的設定,PS:這個東西不知道還有啥用
- localNotification.alertLaunchImage=[[NSBundle mainBundle]pathForResource:@"3" ofType:@"jpg"];
-
- ///這個東西,到時用於定位是哪個notification,以便取消用
- NSDictionary* infoDic=[NSDictionary dictionaryWithObject:@"name" forKey:@"key"];
- localNotification.userInfo=infoDic;
-
- //講推送設定以及資訊加入
- UIApplication* app=[UIApplication sharedApplication];
- BOOL status=YES;
- for (UILocalNotification* notification in app.scheduledLocalNotifications) {
- if ([notification.userInfo objectForKey:@"key"]) {
- status=NO;
- }
- }
-
- if (status) {
- //加入推送(只能加入一次)
- [app scheduleLocalNotification:localNotification];
- }
-
-
-
- NSLog(@"%@",app.scheduledLocalNotifications);
- }
- }
取消本地推送
- ///本地移除
- -(void)removeLocalPushNotification:(UIButton*)sender
- {
- NSLog(@"%s",__FUNCTION__);
- UIApplication* app=[UIApplication sharedApplication];
- //擷取當前應用所有的通知
- NSArray* localNotifications=[app scheduledLocalNotifications];
-
- if (localNotifications) {
-
- for (UILocalNotification* notification in localNotifications) {
-
- NSDictionary* dic=notification.userInfo;
-
- if (dic) {
- NSString* key=[dic objectForKey:@"key"];
- if ([key isEqualToString:@"name"]) {
- //取消推送 (指定一個取消)
- [app cancelLocalNotification:notification];
-
- break;
- }
- }
-
- }
- }
- //取消當前應用所有的推送
- //[app cancelAllLocalNotifications];
-
-
- }
遠程推送
當服務端遠程向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
- [[UIApplication sharedApplication] registerForRemoteNotificationTypes:
- (UIRemoteNotificationTypeAlert|
- UIRemoteNotificationTypeBadge|
- UIRemoteNotificationTypeSound)];
在AppDelegate中加入以下幾個代理方法
[cpp] view plaincopy
- ///Token值成功擷取的時候走的是這個方法(Token值不能帶空格)
- -(void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken
- {
-
- NSLog(@"%@",deviceToken);
-
- }
- ///Token值擷取失敗的時候走的是這個方法
- -(void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error
- {
-
- NSLog(@"%@",error);
- }
- ///應用程式處在開啟狀態,且伺服器有推送訊息過來時,以及通過推送開啟應用程式,走的是這個方法
- -(void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo
- {
- for (id key in userInfo) {
- NSLog(@"%@:%@",key, [userInfo objectForKey:key]);
- }
- ///Icon推送數量設為0
- // application.applicationIconBadgeNumber=0;
- }
應用程式不處在後台,且通過推播通知開啟的時候,如果需要推送下來相關的資訊可以在
[cpp] view plaincopy
- - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
方法中加入
[cpp] view plaincopy
- ///應用程式不處在後台,並且是通過推送開啟應用的時候
- if (launchOptions) {
- ///擷取到推送相關的資訊
- NSDictionary *userInfo = [launchOptions objectForKey:UIApplicationLaunchOptionsRemoteNotificationKey];
- }
服務端PHP推送代碼
[cpp] view plaincopy
- <?php
- $deviceToken= 'ba6d5106503c8e62e68b5df1b36c3b58ced1588c6dabe0fc9e6828961aeb12d6'; //沒有空格
- $body = array("aps" => array("alert" => 'helloHui',"badge" => 2,"sound"=>'default')); //推送方式,包含內容和聲音
- $ctx = stream_context_create();
- //如果在Windows的伺服器上,尋找pem路徑會有問題,路徑修改成這樣的方法:
- //$pem = dirname(__FILE__) . '/' . 'apns-dev.pem';
- //linux 的伺服器直接寫pem的路徑即可
- stream_context_set_option($ctx,"ssl","local_cert","26ck.pem");
- $pass = "123123";
- stream_context_set_option($ctx, 'ssl', 'passphrase', $pass);
- //此處有兩個伺服器需要選擇,如果是開發測試用,選擇第二名sandbox的伺服器並使用Dev的pem認證,如果是正是發布,使用Product的pem並選用正式的伺服器
- // $fp = stream_socket_client("ssl://gateway.push.apple.com:2195", $err, $errstr, 60, STREAM_CLIENT_CONNECT, $ctx);
- $fp = stream_socket_client("ssl://gateway.sandbox.push.apple.com:2195", $err, $errstr, 60, STREAM_CLIENT_CONNECT, $ctx);
- if (!$fp) {
- echo "Failed to connect $err $errstrn";
- return;
- }
- print "Connection OK\n";
- $payload = json_encode($body);
- $msg = chr(0) . pack("n",32) . pack("H*", str_replace(' ', '', $deviceToken)) . pack("n",strlen($payload)) . $payload;
- echo "sending message :" . $payload ."\n";
- fwrite($fp, $msg);
- fclose($fp);?>
[php] view plaincopy
- <pre></pre>
- <pre></pre>
- <pre></pre>
- <pre></pre>
- <pre></pre>
- <pre></pre>
-
- <div style="padding-top:20px">
- <p style="font-size:12px;">著作權聲明:本文為博主原創文章,未經博主允許不得轉載。</p>
- </div>
- 上一篇SpriteKit-粒子效果-SKEmitterNode
- 下一篇將字串中各單詞首字母轉化成大寫,使用回呼函數實現[函數指標]