叙事
今天被ASCII码里的00 结结实实的摆了一道.
lua从GSM卡 AT+CSCA? 取到短信中心号码, 因为是PDU模式, 所以我拿到的是这么个玩意儿:
+CSCA: "002B0038003600310033003000310030003100310032003500300030",145
正则提取出来传给了php. 用php 的 chr(hexdec($str)) 组合就能转成字符串, 打印看了一下:
+8613010112500
没毛病,继续, 存mysql ,存redis .
第一次中毒:
存储的时候不想要前面的+加号, substr($str,1); 没毛病哈. 结果, 任你百般折腾,代码自岿然不动.
没办法 曲线救国 ,转之前 把前面的002B 截取掉, 再转, 可以了.
第二次中毒:
放redis里的时候没毛病, 但是存储mysql的时候, 因为字段长度给的就是13位. 结果只存储了6位进去 . 又是一顿折腾. 怎么打印长度都是 26 ,而不是理所应当的是13 . 敌进我退敌疲我打, 我把数据库的字段长度改成了26 . 进来了.
第三次中毒:
PDU模式发送中英文短信的时候, 要把 8613010112500 格式化成 683110102105F0
我用到了str_split ,有了前两次的毒发 ,知道大概是怎么回事儿了 . 网上查了下, ASCII码里的00 是空字符, 输出不了.
于是了有了下面的测试:
$str = "0038003600310033003000310030003100310032003500300030"; $n = str_split($str,2); $r = ""; for($i=0;$i<count($n);$i++){ if($n[$i] != "00"){ $r .= chr(hexdec($n[$i])); } } echo "长度:".strlen($r)."\r\n"; echo "内容:".$r; echo "\r\n\r\n"; $o = chr(hexdec("00000000")) . chr(hexdec("00000000")) . chr(hexdec("00000000")) . chr(hexdec("00000000")); echo "长度:".strlen($o); echo "\r\n内容:--->>".$o."<<---\r\n";
打印如下:
代码都不难, 吃一堑长一智啊.
btw, 这要是往谁的代码里加上这么一串儿, [坏笑]