PHP: как (правильно) удалить экранированные кавычки в массивах, когда включены магические кавычки

Как вы знаете, когда магические кавычки включены, одинарные кавычки экранируются в значениях, а также в ключах. Большинство решений для удаления магических кавычек во время выполнения только значения unescape, а не ключи. Я ищу решение, которое будет unescape ключи и значения...

я узнал на PHP.net этот фрагмент кода:

$process = array(&$_GET, &$_POST, &$_COOKIE, &$_REQUEST);
while (list($key, $val) = each($process))
{
    foreach ($val as $k => $v)
    {
        unset($process[$key][$k]);
        if (is_array($v))
        {
            $process[$key][stripslashes($k)] = $v;
            $process[] = &$process[$key][stripslashes($k)];
        }
        else
        {
            $process[$key][stripslashes($k)] = stripslashes($v);
        }
    }
}
unset($process);

но мне не нравятся "&" ссылки и массивы, поскольку у меня есть ошибки, такие как этот в прошлом...

есть ли "лучший" способ unescape Magic Цитаты (ключи и значения) во время выполнения, чем выше?

2 ответов


Я думаю, что это немного чище и избежать ошибок ссылка:

function unMagicQuotify($ar) {
  $fixed = array();
  foreach ($ar as $key=>$val) {
    if (is_array($val)) {
      $fixed[stripslashes($key)] = unMagicQuotify($val);
    } else {
      $fixed[stripslashes($key)] = stripslashes($val);
    }
  }
  return $fixed;
}

$process = array($_GET,$_POST,$_COOKIE,$_REQUEST);
$fixed = array();
foreach ($process as $index=>$glob) {
  $fixed[$index] = unMagicQuotify($glob);
}
list($_GET,$_POST,$_COOKIE,$_REQUEST) = $fixed;

array_walk_recursive($_POST, 'stripslashes');

сделайте то же самое для GET и COOKIE.