Escaping Escape Charaktere

Ich versuche, das @ zu imitierjson_encode Bitmask Flags in PHP 5.3.0 implementiert, hier ist die Zeichenfolge, die ich habe:

$s = addslashes('O\'Rei"lly'); // O\'Rei\"lly

Tunjson_encode($s, JSON_HEX_APOS | JSON_HEX_QUOT) gibt Folgendes aus:

"O\\\u0027Rei\\\u0022lly"

Und ich mache dies 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 beim Verstehen Warum muss ich einfache Anführungszeichen ersetzen '\\\'' oder auch"\\'" [surrounding Anführungszeichen ausgeschlossen]) mit'\\\u0027' und nicht nur'\\u0027'.

Hier ist der Code, bei dem ich Probleme beim Portieren nach PHP <5.3 habe:

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));
}

Antworten auf die Frage(12)

Ihre Antwort auf die Frage