使用PHP处理Apple推送通知服务的设备令牌的方法

前端之家收集整理的这篇文章主要介绍了使用PHP处理Apple推送通知服务的设备令牌的方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
这个网站上有很多关于如何处理 PHP中Apple推送通知服务异步返回的错误的信息.我想出了一个PHP方法似乎工作得很好,但我想要一些反馈.

> fflush()的使用是否正确?我在一些例子中看过它,但不是全部.
>我无法让它为有意的坏设备令牌发出错误.为什么?
>此解决方案是否可扩展到数千台设备(假设PHP最大内存增加足够)?
>其他问题?

笔记:
通知的设备令牌在开始时存储在数组中.
– 它不是异步的,但它在发送每个通知后检查(过去)错误,并在最后一次通知后再检查一整秒.
– 它使用较新的“现代”通知格式,而不是原始或扩展格式.
– 它将令牌数组的索引作为标识符发送给APNS.
– 它使用checkAppleErrorResponse()函数,该函数读取前6个字节并返回false或失败的标识符(索引),以便它可以备份并继续下一个标记. (失败后发送的所有令牌都将失效.)

  1. $ctx = stream_context_create();
  2. stream_context_set_option($ctx,'ssl','passphrase',$iosCertPassphrase);
  3. stream_context_set_option($ctx,"ssl","local_cert",$iosCertKey);
  4. $fp = NULL;
  5. $errno = NULL;
  6. $errstr = NULL;
  7.  
  8. // same payload for all
  9. $item2 = chr(2) . pack("n",strlen($payload)) . $payload; // payload item has id 2,a 2-byte length ("n") containing length of payload,then payload
  10.  
  11. $errorID = -1;
  12.  
  13. while ($errorID !== false) {
  14. $fp = stream_socket_client($iosHost . ':' . $iosPort,$errno,$errstr,60,STREAM_CLIENT_CONNECT|STREAM_CLIENT_PERSISTENT,$ctx);
  15.  
  16. if ($fp === FALSE) {
  17. echo('Failed to create socket');
  18. break;
  19. }
  20.  
  21. stream_set_blocking($fp,0);
  22.  
  23. for ($id = $errorID + 1 ; $id < sizeof($iosTokens); $id++) {
  24. $errorID = false;
  25. $item1 = chr(1) . pack('n',32) . pack("H*",$iosTokens[$id]['device_token']); // device token item has 1-byte id 1,2-byte length ("n") containing 32,then 32-byte device token
  26.  
  27. $item3 = chr(3) . pack('n',4) . pack('N',$id); // notification identifier has 1-byte id 3,2-byte length ("n") containing 4,then 4-byte identifier
  28.  
  29. $frame = $item1 . $item2 . $item3;
  30.  
  31. $msg = chr(2) . pack("N",strlen($frame)) . $frame; // for "modern" push notification format,msg has 1-byte id 2,4-byte length ("N") containing the length of the frame,then frame
  32.  
  33. fwrite($fp,$msg);
  34.  
  35. $errorID = checkAppleErrorResponse($fp);
  36. fflush($fp);
  37.  
  38. if ($errorID !== false) // if there's an error,stop now
  39. break;
  40. }
  41.  
  42. // if done with for loop and no errors,pause for a sec and check one last time
  43. if ($errorID === false) {
  44. $read = array($fp);
  45. $null = null;
  46. $changedStreams = stream_select($read,$null,1000000);
  47.  
  48. //check if it is actually false
  49. if ($changedStreams === false)
  50. {
  51. //close stream when done.
  52. socket_close($fp);
  53. fclose($fp);
  54. }
  55. elseif ($changedStreams > 0)
  56. {
  57. // set the error and redo starting after errorID index
  58. $errorID = checkAppleErrorResponse($fp);
  59. }
  60. }
  61. }
  62. }
希望有关.我用过这个.这是基本但坚实的黄金.有点洒水或安全性以及一些更强烈的错误处理,不久之后我就把它推进到一个可以处理我需要它的系统中.

http://www.raywenderlich.com/2941/how-to-write-a-simple-phpmysql-web-service-for-an-ios-app

猜你在找的PHP相关文章