在PHP中打包().非法十六进制数字警告

ayu*_*ush 8 php hex pack

我在php中使用pack()时遇到了一些问题

$currencypair = "EUR/USD";
$buy_sell = "buy";
$alert_device_token =array("a","a","b");
$message = "Your " . $currencypair . " " . $buy_sell . " alert price has been reached!";
$payload['aps'] = array (
  'alert' => $message,
  'badge' => 1,
  'sound' => 'default'
);
$payload = json_encode($payload);

foreach ($alert_device_token as $alert_device)
{
  $apnsMessage = chr(0) . chr(0) . chr(32) . 
                 pack('H*', str_replace(' ', '', $alert_device)) . 
                 chr(0) . chr(strlen($payload)) . $payload;
  echo $apnsMessage;
}
Run Code Online (Sandbox Code Playgroud)

现在有时我会得到以下警告,运行相同的代码 -

Warning: pack() [function.pack]: Type H: illegal hex digit g in /code/FR2BVl
Run Code Online (Sandbox Code Playgroud)

虽然非法的十六进制数字不变.有关此警告的任何想法以及删除它的方法.

检查它在这里

Sta*_*asM 6

pack 将十六进制数转换为二进制数,例如:

  echo pack("H*", "2133")
Run Code Online (Sandbox Code Playgroud)

生成!3,因为!代码为0x21,3代码为0x33.由于g不是十六进制数字,因此给出警告.要对包的H格式有用,参数必须是十六进制数.如果$alert_device不是 - 你应该使用别的东西,取决于它是什么以及你期望的结果.


Run*_*hya 6

错误的原因之一与校验和有关,

由于PHP的整数类型已签名,因此许多crc32校验和将在32位平台上产生负整数.在64位安装中,所有crc32()结果都是正整数.因此,您需要使用sprintf()或printf()的"%u"格式化程序以十进制格式获取无符号crc32()校验和的字符串表示形式. http://www.php.net/crc32

要修复错误,这可能就足够了,

sprintf('%u', CRC32($someString))
Run Code Online (Sandbox Code Playgroud)

在这种情况下,

pack('H*', str_replace(' ', '', sprintf('%u', CRC32($alert_device))))
Run Code Online (Sandbox Code Playgroud)

参考:https://github.com/bearsunday/BEAR.Package/issues/136