我在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)
虽然非法的十六进制数字不变.有关此警告的任何想法以及删除它的方法.
检查它在这里住
pack
将十六进制数转换为二进制数,例如:
echo pack("H*", "2133")
Run Code Online (Sandbox Code Playgroud)
生成!3
,因为!
代码为0x21,3
代码为0x33.由于g
不是十六进制数字,因此给出警告.要对包的H
格式有用,参数必须是十六进制数.如果$alert_device
不是 - 你应该使用别的东西,取决于它是什么以及你期望的结果.
错误的原因之一与校验和有关,
由于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
归档时间: |
|
查看次数: |
26767 次 |
最近记录: |