出于某种原因,我的所有引号都被转义并显示为\“。之前,它没关系。然后我查看了phpinfo()并看到我的magic_quotes_gpc已打开。但是,我找不到目录/ usr / local / lib /其中php.ini文件是,我无法编辑我的.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);
}
但是,我的页面上的“和”仍然有反斜杠。
我做错了什么?
答案 0 :(得分:2)
尝试使用此代码,它在过去对我有用。
<?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);
}
答案 1 :(得分:2)
你使用哪个PHP版本?
如果您使用的版本大于5.2
,则可以使用filter_input()
或filter_input_array()
。它似乎忽略了magic_quotes_gpc
- 指令的设置并使用原始数据(默认过滤器为FILTER_UNSAFE_RAW
)