2014-10-03 172 views
0

我想用一個php腳本從數據庫發送多個PN。表中有3個設備令牌,但腳本只將它發送給第一個設備令牌。iOS發送多個推送通知

這裏的腳本,有人想法。

$ctx = stream_context_create(); 
stream_context_set_option($ctx, 'ssl', 'local_cert', 'DEV.pem'); 
stream_context_set_option($ctx, 'ssl', 'passphrase', $passphrase); 

$fp = stream_socket_client(
    'ssl://gateway.sandbox.push.apple.com:2195', $err, 
    $errstr, 60, STREAM_CLIENT_CONNECT|STREAM_CLIENT_PERSISTENT, $ctx); 

if (!$fp){ 
    exit("Failed to connect: $err $errstr" . PHP_EOL); 
} 

$ausgabe.= 'Connected to APNS' . PHP_EOL . '<hr>'; 

$body['aps'] = array(
    'alert' => $message, 
    'sound' => 'note.wav', 
    'badge' => 1 
); 

$payload = json_encode($body); 

$selectSQL = 'SELECT * from app_pushnotification'; 
$result = mysql_query($selectSQL); 
while($row = mysql_fetch_array($result)){ 
    $i+=1; 
    $ausgabe.= $i.' - '. $row['device_token'].' '; 
    $deviceToken = $row['device_token']; 

    $msg = chr(0) . pack('n', 32) . pack('H*', $deviceToken) . pack('n', strlen($payload)) . $payload; 

    $result = fwrite($fp, $msg, strlen($msg)); 

    if (!$result){ 
     $ausgabe.='Message to not delivered' . PHP_EOL . '<hr>'; 
    } else { 
     $ausgabe.='Message to successfully delivered' . PHP_EOL . '<hr>'; 
    } 

} 

$ausgabe.='close connection'; 
fclose($fp); 

} 
echo $ausgabe; 

電賀凱文

+0

嘗試每條消息使用一個連接。關閉/打開循環中的連接。 – kezi 2014-10-03 18:29:05

+0

@kdogisthebest這是一個壞主意。太慢了! – Qualcuno 2014-10-03 18:30:13

+0

Kevin,查詢返回多少行?你確定錯誤不在數據庫中,而是在APNS服務器上? – Qualcuno 2014-10-03 18:31:11

回答

2

你的錯誤是你在循環改變$result值。因此腳本無法讀取下一行數組。

$ctx = stream_context_create(); 
stream_context_set_option($ctx, 'ssl', 'local_cert', 'DEV.pem'); 
stream_context_set_option($ctx, 'ssl', 'passphrase', $passphrase); 

$fp = stream_socket_client(
    'ssl://gateway.sandbox.push.apple.com:2195', $err, 
    $errstr, 60, STREAM_CLIENT_CONNECT|STREAM_CLIENT_PERSISTENT, $ctx); 

if (!$fp){ 
    exit("Failed to connect: $err $errstr" . PHP_EOL); 
} 

$ausgabe.= 'Connected to APNS' . PHP_EOL . '<hr>'; 

$body['aps'] = array(
    'alert' => $message, 
    'sound' => 'note.wav', 
    'badge' => 1 
); 

$payload = json_encode($body); 

$selectSQL = 'SELECT * from app_pushnotification'; 
$result = mysql_query($selectSQL); 
while($row = mysql_fetch_array($result)){ 
    $i+=1; 
    $ausgabe.= $i.' - '. $row['device_token'].' '; 
    $deviceToken = $row['device_token']; 

    $msg = chr(0) . pack('n', 32) . pack('H*', $deviceToken) . pack('n', strlen($payload)) . $payload; 

    $write_result = fwrite($fp, $msg, strlen($msg)); 

    if (!$write_result){ 
     $ausgabe.='Message to not delivered' . PHP_EOL . '<hr>'; 
    } else { 
     $ausgabe.='Message to successfully delivered' . PHP_EOL . '<hr>'; 
    } 

} 

$ausgabe.='close connection'; 
fclose($fp); 

} 
echo $ausgabe; 

注意,第二$result =現在$write_result =