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;