php實(shí)現(xiàn)ios推送的方法:首先把要發(fā)送的消息以及iPhone標(biāo)識(shí)打包,并發(fā)給APNS;然后查找有相應(yīng)標(biāo)識(shí)的iPhone,并把消息發(fā)送到iPhone;最后把發(fā)來的消息傳遞給相應(yīng)的應(yīng)用程序,并且按照設(shè)定彈出Push通知即可。
廣陽(yáng)網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián),廣陽(yáng)網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為廣陽(yáng)1000多家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)營(yíng)銷網(wǎng)站建設(shè)要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的廣陽(yáng)做網(wǎng)站的公司定做!
推薦:《PHP視頻教程》
IOS推送消息是許多IOS應(yīng)用都具備的功能,最近也在研究這個(gè)功能,參考了很多資料終于搞定了,下面就把步驟拿出來分享下:
iOS消息推送的工作機(jī)制可以簡(jiǎn)單的用下圖來概括:
Provider是指某個(gè)iPhone軟件的Push服務(wù)器,APNS是Apple Push Notification Service的縮寫,是蘋果的服務(wù)器。
上圖可以分為三個(gè)階段:
第一階段:應(yīng)用程序把要發(fā)送的消息、目的iPhone的標(biāo)識(shí)打包,發(fā)給APNS。
第二階段:APNS在自身的已注冊(cè)Push服務(wù)的iPhone列表中,查找有相應(yīng)標(biāo)識(shí)的iPhone,并把消息發(fā)送到iPhone。
第三階段:iPhone把發(fā)來的消息傳遞給相應(yīng)的應(yīng)用程序,并且按照設(shè)定彈出Push通知。
從上圖我們可以看到:
1、應(yīng)用程序注冊(cè)消息推送。
2、iOS從APNS Server獲取device token,應(yīng)用程序接收device token。
3、應(yīng)用程序?qū)evice token發(fā)送給PUSH服務(wù)端程序。
4、服務(wù)端程序向APNS服務(wù)發(fā)送消息。
5、APNS服務(wù)將消息發(fā)送給iPhone應(yīng)用程序。
無(wú)論是iPhone客戶端和APNS,還是Provider和APNS,都需要通過證書進(jìn)行連接。
下面我介紹一下幾種用到的證書。
一、CSR文件
1、生成Certificate Signing Request(CSR)
2、填寫你的郵箱和常用名稱,并選擇保存到硬盤。
點(diǎn)擊繼續(xù):
這樣就在本地生成了一個(gè)Push.certSigningRequest文件。
二、p12文件
1、導(dǎo)出密鑰。
2、輸入你的密碼。
這樣就生成了一個(gè)Push.p12文件。
三、SSL certificate文件
1、用你付過費(fèi)的帳號(hào)登錄到iOS Provisioning Portal,并新建一個(gè)App ID,這個(gè)過程可以參考:iOS應(yīng)用的真機(jī)調(diào)試,這樣就會(huì)生成下面這條記錄:
2、點(diǎn)擊右側(cè)的Configure:
3、點(diǎn)擊Development Push SSL Certificate一行后的Configure:
4、點(diǎn)擊Continue:
5、選擇前面生成好的Push.certSigningRequest文件,點(diǎn)擊Generate,出現(xiàn)如下所示的頁(yè)面:
6、點(diǎn)擊Continue:
7、點(diǎn)擊Download,并將文件命名為aps_developer_identity.cer。
8、點(diǎn)擊Done,你會(huì)發(fā)現(xiàn)狀態(tài)變成了Enabled:
到現(xiàn)在為止,我們已經(jīng)生成了三個(gè)文件:
1、Push.certSigningRequest
2、Push.p12
3、aps_developer_identity.cer
雙擊aps_developer_dientity.cer 注冊(cè)到你的鑰匙串中,這樣你的鑰匙串中就會(huì)有
二、準(zhǔn)備profile證書,因?yàn)橥扑拖⒅荒茉僬鏅C(jī)上測(cè)試,所以要建一個(gè)profile證書
點(diǎn)擊"new profile"為上面新建的APP ID建個(gè)profile ,成功之后下載*_Dev_Profile.mobileprovision
雙擊將其加入到xcode 的Provisioning Profiles 中,這里有一點(diǎn)要注意,再將這個(gè)加入xcode之前如果之前已經(jīng)加入過一定要把之前加入的刪掉,如果有多個(gè)的話會(huì)出錯(cuò)。
三、工程代碼
到這里證書已經(jīng)準(zhǔn)備完畢,接下來,我們?cè)趚code中新建一個(gè)測(cè)試工程,注意設(shè)置工程的Bundle Identifier必須與上面建的APP ID 里的相同
在didFinishLaunchingWithOptions 中加入一下代碼
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { [self.window makeKeyAndVisible]; [[UIApplication sharedApplication] registerForRemoteNotificationTypes: UIRemoteNotificationTypeBadge | UIRemoteNotificationTypeSound | UIRemoteNotificationTypeAlert]; return YES; } - (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)pToken { NSLog(@"regisger success:%@", pToken); //注冊(cè)成功,將deviceToken保存到應(yīng)用服務(wù)器數(shù)據(jù)庫(kù)中 } - (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo{ // 處理推送消息 UIAlertView *alert=[[UIAlertView alloc]initWithTitle:@"通知" message:@"我的信息" delegate:selfcancelButtonTitle:@"取消" otherButtonTitles:nil, nil]; [alert show]; [alert release]; NSLog(@"%@", userInfo); } - (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error { NSLog(@"Regist fail%@",error); }
到這里一切順利的話我們就可以在真機(jī)運(yùn)行了,注冊(cè)成功我們會(huì)得到iphone 的deviceToken,
My token is:
<740f4707 bebcf74f 9b7c25d4 8e335894 5f6aa01d a5ddb387 462c7eaf 61bb78ad>
四、在應(yīng)用服務(wù)器采用php的方式將消息推送給APNS,
1、php連接APNS也是需要證書的,還記得我們上面獲得的幾個(gè)證書嗎?打開終端,對(duì)上面的證書做如下處理,
cd 進(jìn)入證書所在目錄
把.cer文件轉(zhuǎn)換成.pem文件:
$ openssl x509 -in aps_developer_identity.cer -inform der -out PushChatCert.pem
把私鑰Push.p12文件轉(zhuǎn)換成.pem文件:
$ openssl pkcs12 -nocerts -out PushChatKey.pem -in Push.p12 Enter Import Password: MAC verified OK Enter PEM pass phrase: Verifying – Enter PEM pass phrase:
你首先需要為.p12文件輸入passphrase密碼短語(yǔ),這樣OpenSSL可以讀它。然后你需要鍵入一個(gè)新的密碼短語(yǔ)來加密PEM文件。還是使用”pushchat”來作為PEM的密碼短語(yǔ)。你需要選擇一些更安全的密碼短語(yǔ)。
注意:如果你沒有鍵入一個(gè)PEM passphrase,OpenSSL將不會(huì)返回一個(gè)錯(cuò)誤信息,但是產(chǎn)生的.pem文件里面將不會(huì)含有私鑰。
最后。把私鑰和證書整合到一個(gè).pem文件里:
$ cat PushChatCert.pem PushChatKey.pem > ck.pem
為了測(cè)試證書是否工作,執(zhí)行下面的命令:
$ telnet gateway.sandbox.push.apple.com 2195 Trying 17.172.232.226… Connected to gateway.sandbox.push-apple.com.akadns.net. Escape character is ‘^]’.
它將嘗試發(fā)送一個(gè)規(guī)則的,不加密的連接到APNS服務(wù)。如果你看到上面的反饋,那說明你的MAC能夠到達(dá)APNS。按下Ctrl+C 關(guān)閉連接。如果得到一個(gè)錯(cuò)誤信息,那么你需要確保你的防火墻允許2195端口。
然后再次連接,這次用我們的SSL證書和私鑰來設(shè)置一個(gè)安全的連接:
$ openssl s_client -connect gateway.sandbox.push.apple.com:2195 -cert PushChatCert.pem -key PushChatKey.pem Enter pass phrase for PushChatKey.pem:
你會(huì)看到一個(gè)完整的輸出,讓你明白OpenSSL在后臺(tái)做什么。如果連接是成功的,你可以鍵入一些字符。當(dāng)你按下回車后,服務(wù)就會(huì)斷開連接。如果在建立連接時(shí)有問題,OpenSSL將會(huì)給你一個(gè)錯(cuò)誤消息
ck.pem文件就是我們需要得到php連接APNS 的文件,將ck.pem和push.php放入同一目錄上傳到服務(wù)器,push.php的代碼如下:
$message, 'sound' => 'default' ); // Encode the payload as JSON $payload = json_encode($body); // Build the binary notification $msg = chr(0) . pack('n', 32) . pack('H*', $deviceToken) . pack('n', strlen($payload)) . $payload; // Send it to the server $result = fwrite($fp, $msg, strlen($msg)); if (!$result) echo 'Message not delivered' . PHP_EOL; else echo 'Message successfully delivered' . PHP_EOL; // Close the connection to the server fclose($fp); ?>
接下來我們?cè)L問http://localhost/push/push.php
iphone就會(huì)接收到一條推送消息了,如果有問題的話就檢查上面的操作步驟,特別是加紅的部分
另外去除標(biāo)記的方法為,在viewDidApper中加入
int badge = [UIApplication sharedApplication].applicationIconBadgeNumber; if(badge > 0) { badge--; [UIApplication sharedApplication].applicationIconBadgeNumber = badge; }