遠程推送php
當服務端遠程向APNS推送至一臺離線的設備時,蘋果服務器Qos組件會自動保留一份最新的通知,等設備上線後,Qos將把推送發送到目標設備上linux
客戶端須要注意的json
bundle ID與App Id一致服務器
設備Token能正常獲取app
若爲沙盒測試,證書得使用developer的socket
單設備ide
如上圖所示:咱們的服務端將須要推送的相關信息提交到APNS(Apple Push Notification Service),由APNS在Push服務IOS設備列表中找到對應的設備,並將信息推到終端上,終端上再推到客戶端APP上
測試
多設備ui
流程大概是這樣的spa
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文件
openssl x509 -in aps_development.cer -inform der -out PushChatCert.pem
openssl pkcs12 -nocerts -out PushChatKey.pem -in Push.p12
cat PushChatCert.pem PushChatKey.pem > newck.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>