I thought I was making my life easy and being future-conscious by saving some content as bits of JSON in custom post_meta fields. Unfortunately, WordPress doesn’t agree and is making my life incredibly difficult.
I have a JSON string that looks essentially like this. This is just one bit, and the comment string is just some dummy unicode entities. The whole thing is generated w/ json_encode.
{
"0": {
"name": "Chris",
"url": "testdomain.com",
"comment": "\u00a5 \u00b7 \u00a3 \u00b7 \u20ac \u00b7 \u00b7 \u00a2 \u00b7 \u20a1 \u00b7 \u20a2 \u00b7 \u20a3 \u00b7 \u20a4 \u00b7 \u20a5 \u00b7 \u20a6 \u00b7 \u20a7 \u00b7 \u20a8 \u00b7 \u20a9 \u00b7 \u20aa \u00b7 \u20ab \u00b7 \u20ad \u00b7 \u20ae \u00b7 \u20af \u00b7 \u20b9"
}
}
Unfortunately after I save it with update_post_meta
, it comes out looking like this:
{
"0": {
"name": "Chris",
"url": "testdomain.com",
"comment": "u00a5 u00b7 u00a3 u00b7 u20ac u00b7 u00b7 u00a2 u00b7 u20a1 u00b7 u20a2 u00b7 u20a3 u00b7 u20a4 u00b7 u20a5 u00b7 u20a6 u00b7 u20a7 u00b7 u20a8 u00b7 u20a9 u00b7 u20aa u00b7 u20ab u00b7 u20ad u00b7 u20ae u00b7 u20af u00b7 u20b9"
}
}
And with the slashes stripped, it can’t be json_decode
d back into useful content.
Any ideas why WordPress might be doing this, and if there is a way to avoid it? I can’t use the JSON_UNESCAPED_UNICODE flag because this is a PHP 5.3.x install, and I’ve already tried encoding with htmlentities
before the content is passed to json_encode
, but that only captures a small subset of UTF-8 entities.
Thanks in advance!
(EDIT: FWIW, I know I could just save an array directly to post_meta and it’d be serialized and magic would happen but I just like the idea of having the data stored as JSON. If there isn’t an easy, elegant solution I’ll cave, but I’m very much hoping there is an easy, elegant solution!)