溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

詳解IOS開發(fā)中生成推送的pem文件

發(fā)布時(shí)間:2020-10-09 16:39:05 來(lái)源:腳本之家 閱讀:126 作者:lqh 欄目:移動(dòng)開發(fā)

詳解IOS開發(fā)中生成推送的pem文件

具體步驟如下:

        首先,需要一個(gè)pem的證書,該證書需要與開發(fā)時(shí)簽名用的一致。 具體生成pem證書方法如下:

1. 登錄到 iPhone Developer Connection Portal(http://developer.apple.com/iphone/manage/overview/index.action )并點(diǎn)擊 App IDs

2. 創(chuàng)建一個(gè)不使用通配符的 App ID 。通配符 ID 不能用于推送通知服務(wù)。例如,  com.itotem.iphone

3. 點(diǎn)擊App ID旁的“Configure”,然后按下按鈕生產(chǎn) 推送通知許可證。根據(jù)“向?qū)А?的步驟生成一個(gè)簽名并上傳,最后下載生成的許可證。

4. 通過(guò)雙擊.cer文件將你的 aps_developer_identity.cer 引入Keychain中。

5. 在Mac上啟動(dòng) Keychain助手,然后在login keychain中選擇 Certificates分類。你將看到一個(gè)可擴(kuò)展選項(xiàng)“Apple Development Push Services”

6. 擴(kuò)展此選項(xiàng)然后右擊“Apple Development Push Services” > Export “Apple Development Push Services ID123”。保存為 apns-dev-cert.p12文件。

7. 擴(kuò)展“Apple Development Push Services” 對(duì)“Private Key”做同樣操作,保存為 apns-dev-key.p12 文件。

8. 需要通過(guò)終端命令將這些文件轉(zhuǎn)換為PEM格式:

openssl pkcs12 -clcerts -nokeys -out apns-dev-cert.pem -in apns-dev-cert.p12
openssl pkcs12 -nocerts -out apns-dev-key.pem -in apns-dev-key.p12

9. 如果你想要移除密碼,要么在導(dǎo)出/轉(zhuǎn)換時(shí)不要設(shè)定或者執(zhí)行:

openssl rsa -in apns-dev-key.pem -out apns-dev-key-noenc.pem

10. 最后,你需要將鍵和許可文件合成為apns-dev.pem文件,此文件在連接到APNS時(shí)需要使用:

cat apns-dev-cert.pem apns-dev-key-noenc.pem > apns-dev.pem

實(shí)現(xiàn)代碼:

<?php      
$_POST['token'] = "fe28006a9d57b0727514cf42e9549446f0d4fc509cdexxxxxxxxxx"; 
    $deviceToken = $_POST['token']; //取得設(shè)備的Token,獲取方法便見下文    
    $body = array("aps" => array("alert" => "message123gggg32323333", "badge" => 1, "sound"=>'default')); //推送方式,包括了提示內(nèi)容,提示方式和提示聲音。 
     
    $ctx = stream_context_create(); 
     
    //如果在Windows的服務(wù)器上,尋找pem路徑會(huì)有問題,路徑修改成這樣的方法: 
    $pem = !empty($this->cfg['isga']) && $this->cfg['isga'] == 2?'apns-dev.pem':'apns-dev.pem'; //臨時(shí)全部為開發(fā)狀態(tài) 
    stream_context_set_option($ctx, 'ssl', 'local_cert', "/data/web/cert/".$pem); 
    //linux 的服務(wù)器直接寫pem的路徑即可 
     
    stream_context_set_option($ctx, 'ssl', 'local_cert', <pre name="code" class="html">"/data/web/cert/".$pem); 
<pre name="code" class="html"><pre name="code" class="html">    //如果你的pem存有密碼,需要加一個(gè)密碼登陸語(yǔ)句   
stream_context_set_option($ctx, 'ssl', 'passphrase', ''); 
     
    //如果你的pem存有密碼,需要加一個(gè)密碼登陸語(yǔ)句     
    //$pass = ”123123“; 
    //stream_context_set_option($ctx, ‘ssl', ‘passphrase', $pass); 
     
    //此處有兩個(gè)服務(wù)器需要選擇,如果是開發(fā)測(cè)試用,選擇第二名sandbox的服務(wù)器并使用Dev的pem證書,如果是正是發(fā)布,使用Product的pem并選用正式的服務(wù)器     
    $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) {     
      print_r("Failed to connect $err $errstrn");     
      return;     
    }     
    print_r("Connection OK\n");     
    $payload = json_encode($body);     
    $msg = chr(0).pack("n", 32).pack('H*', str_replace(' ', '', $deviceToken)).pack("n",strlen($payload)).$payload;         
    print_r("sending message :".$payload."\n");     
    fwrite($fp, $msg);     
    fclose($fp); 


以上就是IOS開發(fā)中生成推送的pem文件的實(shí)例詳解,如有疑問請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI