PHP数组跨语言交互应优先用json_encode()替代serialize(),因其输出标准JSON且兼容Python/JS/Go等;但需规避资源、闭包及对象限制,中文加JSON_UNESCAPED_UNICODE,浮点数精度敏感时转字符串处理。

PHP 数组序列化默认用 serialize(),但不兼容其他语言
PHP 默认的 serialize() 生成带类型标识和长度前缀的二进制风格字符串(如 a:2:{i:0;s:3:"foo";i:1;s:3:"bar";}),其他语言基本无法解析。如果要和 Python、JavaScript、Go 等交互,必须换序列化方式。
改用 json_encode() 是最常用兼容方案
json_encode() 输出标准 JSON 字符串,跨语言支持好,但有硬性限制:数组键名只能是数字或字符串;值不能是资源、闭包、对象(除非实现 JsonSerializable);中文默认转 Unicode(可加 JSON_UNESCAPED_UNICODE)。
常见适配建议:
- 确保数组不含
resource或callable类型,否则json_encode()返回false - 含中文时加上标志:
json_encode($arr, JSON_UNESCAPED_UNICODE) - 空数组/对象会分别输出
[]和{},注意接收方是否区分这两种结构 - 浮点数精度可能丢失(JSON 规范无精度保证),敏感场景需转字符串再 encode
需要保留 PHP 特有类型?考虑 igbinary 或自定义协议
igbinary 是 C 扩展,比 serialize() 更紧凑、更快,且部分语言(如 Python 的 pylibigbinary)有解码支持。但它不是标准,需两端都装扩展,部署成本高。
立即学习“PHP免费学习笔记(深入)”;
若必须用原生 PHP 且要兼容,又需支持对象/资源等,只能自己约定轻量协议,比如:
json_encode([
'type' => 'array',
'data' => $arr,
'php_version' => PHP_VERSION
])
但这类方案维护成本高,仅限封闭系统内部使用。
反序列化时别硬写 unserialize(),先判断格式
混合环境里,存储或传输的数据可能来自不同序列化方式。直接调 unserialize() 遇到 JSON 字符串会报错 Notice: unserialize(): Error at offset 0。
安全做法是加检测逻辑:
- 开头是
{或[→ 用json_decode($s, true) - 开头是
a:、O:、s:等 → 再走unserialize() - 用
json_last_error() === JSON_ERROR_NONE判定 JSON 是否有效,而非仅靠首字符
多语言协作中,序列化格式一旦选错,调试时往往卡在“数据看起来对,但对方解不出来”,关键得确认双方用的是同一套编码规则和边界处理(比如键名是否强制转字符串、null 怎么表示)。











