Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/rust/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如果php.ini/.htaccess不可编辑,如何删除魔术引号?_Php_Escaping_Magic Quotes Gpc - Fatal编程技术网

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

如果php.ini/.htaccess不可编辑,如何删除魔术引号?,php,escaping,magic-quotes-gpc,Php,Escaping,Magic Quotes Gpc,出于某种原因,我的所有引号都被转义并显示为\“。之前,这还可以。然后我查看了phpinfo(),发现我的magic_quotes_gpc已打开。但是,我找不到php.ini文件所在的目录/usr/local/lib/并且我无法编辑我的.htaccess文件(获取500个内部服务器错误) 我尝试将其放在脚本文件(包含在所有页面中)的顶部: 但是,我的页面上的“and”仍然有反斜杠 我做错了什么?试试这段代码,它过去对我很有用 <?php if (function_exists('get_ma

出于某种原因,我的所有引号都被转义并显示为\“。之前,这还可以。然后我查看了phpinfo(),发现我的magic_quotes_gpc已打开。但是,我找不到php.ini文件所在的目录/usr/local/lib/并且我无法编辑我的.htaccess文件(获取500个内部服务器错误)

我尝试将其放在脚本文件(包含在所有页面中)的顶部:

但是,我的页面上的“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
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\u input()
filter\u input\u array()
。它似乎忽略了
magic\u quotes\u gpc
-指令的设置,并使用原始数据(默认的过滤器是
filter\u UNSAFE\u raw

您使用哪个PHP版本


如果使用的版本大于
5.2
,则可以使用
filter\u input()
filter\u input\u array()
。它似乎忽略了
magic\u quotes\u gpc
-指令的设置,并使用原始数据(默认过滤器为
filter\u UNSAFE\u raw

联系或替换您的Web主机。您使用变量引用/别名的方式实际上并没有达到您可能想到的效果。我建议基于
$GLOBALS
数组构建一些东西(根本不需要引用)。但实际上,根本原因是您配置错误的Web主机。Magic quotes GPC enabled表示您的Web主机没有安全感。您在.htaccess文件中放了什么?另外,您是否尝试过
ini\u集('magic\u quotes\u runtime',0)从其他示例中选择一个,并确保它确实是php脚本中调用的第一件事。您已经创建了对数组的引用,但是您的循环没有使用对它们生成的键的引用,因此,您正在删除数据的副本,而不是原始数据。请联系或替换您的Web主机。您使用变量引用/别名的方式实际上并没有按照您的想法进行操作。我建议基于
$GLOBALS
数组构建一些东西(根本不需要引用)。但实际上,根本原因是您配置错误的Web主机。Magic quotes GPC enabled表示您的Web主机没有安全感。您在.htaccess文件中放了什么?另外,您是否尝试过
ini\u集('magic\u quotes\u runtime',0)从其他示例中选择一个,并确保它确实是在php脚本中调用的第一件事。您已经创建了对数组的引用,但是您的循环没有使用对它们生成的键的引用,因此您正在删除数据的副本,而不是原始数据。