在 PHP 中,插入 json 字符串至 MySQL 中,中文已经被编码后的处理
1、在 PHP 中,插入 json 字符串(其中的中文已经被编码)至 MySQL 中,中文已经被编码。如图1
insert into `table` ( `column`, ) values ( '{\"custom\":\"\",\"result\":{\"ack\":\"false\",\"attr1\":\"\",\"attr2\":\"\",\"channel_code\":\"\",\"childList\":[],\"delay_type\":\"\",\"is_changenumbers\":\"\",\"is_delay\":\"\",\"is_remote\":\"\",\"is_residential\":\"\",\"label_url\":\"\",\"message\":\"%E7%94%B3%E6%8A%A5%E4%BB%B7%E5%80%BC%E5%BF%85%E9%A1%BB%E5%A4%A7%E4%BA%8E0\",\"order_id\":\"\",\"order_privatecode\":\"\",\"order_transfercode\":\"\",\"orderpricetrial_amount\":\"\",\"orderpricetrial_currency\":\"\",\"post_customername\":\"\",\"product_tracknoapitype\":\"\",\"reference_number\":\"\",\"return_address\":\"\",\"tracking_number\":\"\"}}' )
2、尝试直接将整个 json 字符串进行 URL解码。而不是将 json 转换为数组,然后再遍历数组,将每一个值进行 URL解码,最后再将数组编码为 json 字符串。使用在线工具尝试 URL 解码,最后再格式化,格式化成功,发现此方案可行。如图2
3、最后在代码中实现如下
isset($result['transport_back_result']) ? urldecode($result['transport_back_result']) : ''
4、查看 MySQL 中的 json 字符串,确认中文已经被 URL解码,符合预期。如图3
5、但是,仍然存在请求参数中有中文未被正常显示的情况。原因在于请求参数是用 json_encode($requestParamsData) 实现的,然后返回。最终决定先 json 解码,再 json 编码,编码时添加参数 JSON_UNESCAPED_UNICODE。JSON_UNESCAPED_UNICODE 表示以字面编码多字节 Unicode 字符(默认是编码成 \uXXXX)。
{"trade_type":"ZYXT","order_returnsign":"N","duty_type":"DDU","cargo_type":"B","consignee_name":"\u5ba2\u6237\u59d3\u540d"}
{ "trade_type": "ZYXT", "order_returnsign": "N", "duty_type": "DDU", "cargo_type": "B", "consignee_name": "客户姓名" }
json_encode(json_decode($str, true), JSON_UNESCAPED_UNICODE);
{"trade_type":"ZYXT","order_returnsign":"N","duty_type":"DDU","cargo_type":"B","consignee_name":"客户姓名"}
近期评论