如何删除魔术引号如果php.ini/.Htaccess不可编辑


How to remove magic quotes if php.ini/.htaccess are not editable?

由于某种原因,我所有的引号都被转义并显示为'"。以前,还好。然后我查看了phpinfo(),看到我的magic_quotes_gpc是打开的。但是,我找不到php.ini文件所在的目录/usr/local/lib/,我无法编辑我的。htaccess文件(得到500内部服务器错误)。

我试着把这个放在我的脚本文件(它包含在所有页面中)的顶部:

if (get_magic_quotes_gpc()) {
    $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);
}

但是,我的页面上的"and"仍然有反斜杠。

我做错了什么?

试一下这个代码,它过去对我有效。

<?php
if (function_exists('get_magic_quotes_gpc') && get_magic_quotes_gpc()) {
        $quotes_sybase = strtolower(ini_get('magic_quotes_sybase'));
        $unescape_function = (empty($quotes_sybase) || $quotes_sybase === 'off') ? 'stripslashes($value)' : 'str_replace("''''","''",$value)';
    $stripslashes_deep = create_function('&$value, $fn', '
        if (is_string($value)) {
            $value = ' . $unescape_function . ';
        } else if (is_array($value)) {
            foreach ($value as &$v) $fn($v, $fn);
        }
    ');
    // Unescape data
    $stripslashes_deep($_POST, $stripslashes_deep);
    $stripslashes_deep($_GET, $stripslashes_deep);
    $stripslashes_deep($_COOKIE, $stripslashes_deep);
    $stripslashes_deep($_REQUEST, $stripslashes_deep);
}

您使用的是哪个版本的php ?

如果您使用的版本大于5.2,则可以使用filter_input()filter_input_array()。它似乎忽略了magic_quotes_gpc指令的设置,并使用原始数据(默认过滤器是FILTER_UNSAFE_RAW)