Ich versuche, die json_encode
Bitmaske flags in PHP 5.3.0 implementiert zu imitieren, hier ist die Zeichenfolge ich habe:Escaping Escape-Zeichen
$s = addslashes('O\'Rei"lly'); // O\'Rei\"lly
json_encode($s, JSON_HEX_APOS | JSON_HEX_QUOT)
Doing gibt der folgende:
"O\\\u0027Rei\\\u0022lly"
und ich mache das derzeit in PHP-Versionen älter als 5.3.0:
str_replace(array('\\"', "\\'"), array('\\u0022', '\\\u0027'), json_encode($s))
or
str_replace(array('\\"', '\\\''), array('\\u0022', '\\\u0027'), json_encode($s))
Welche richtig das gleiche Ergebnis ausgibt:
"O\\\u0027Rei\\\u0022lly"
Ich habe Probleme zu verstehen, warum ich Sie ('\\\''
oder sogar "\\'"
[umschließenden Anführungszeichen ausgeschlossen]) mit '\\\u0027'
und nicht nur '\\u0027'
ersetzen müssen .
Hier ist der Code, den ich habe Probleme zu PHP < 5.3 Portierung mit:
if (get_magic_quotes_gpc() && version_compare(PHP_VERSION, '6.0.0', '<'))
{
/* JSON_HEX_APOS and JSON_HEX_QUOT are availiable */
if (version_compare(PHP_VERSION, '5.3.0', '>=') === true)
{
$_GET = json_encode($_GET, JSON_HEX_APOS | JSON_HEX_QUOT);
$_POST = json_encode($_POST, JSON_HEX_APOS | JSON_HEX_QUOT);
$_COOKIE = json_encode($_COOKIE, JSON_HEX_APOS | JSON_HEX_QUOT);
$_REQUEST = json_encode($_REQUEST, JSON_HEX_APOS | JSON_HEX_QUOT);
}
/* mimic the behaviour of JSON_HEX_APOS and JSON_HEX_QUOT */
else if (extension_loaded('json') === true)
{
$_GET = str_replace(array(), array('\\u0022', '\\u0027'), json_encode($_GET));
$_POST = str_replace(array(), array('\\u0022', '\\u0027'), json_encode($_POST));
$_COOKIE = str_replace(array(), array('\\u0022', '\\u0027'), json_encode($_COOKIE));
$_REQUEST = str_replace(array(), array('\\u0022', '\\u0027'), json_encode($_REQUEST));
}
$_GET = json_decode(stripslashes($_GET));
$_POST = json_decode(stripslashes($_POST));
$_COOKIE = json_decode(stripslashes($_COOKIE));
$_REQUEST = json_decode(stripslashes($_REQUEST));
}
Warum die downvote? –