给apache2.2加上mod_encoding模块後 php5.2.0 处理url出现bug_php技巧
程序员文章站
2024-01-16 10:13:52
...
这个问题是mod_encoding已经先一步处理了url ,而PHP又解了一次
例如
x.php?s=%252B%2F%2B%2F
那么$_GET['s']得到的是
+/ /
urlencode("+") = %2B
urlencode("%2B") = %252B
所以,这个url被decode了两次
第一次是
urldecode( "%252B%2F%2B%2F") = %2B/+/
urldecode( "%2B/+/") = +/ /
解决办法
修改httpd.conf 将
EncodingEngine on
这一段配置移到需要的vitualHost里去,这个不能和php脚本并存。
例如
x.php?s=%252B%2F%2B%2F
那么$_GET['s']得到的是
+/ /
urlencode("+") = %2B
urlencode("%2B") = %252B
所以,这个url被decode了两次
第一次是
urldecode( "%252B%2F%2B%2F") = %2B/+/
urldecode( "%2B/+/") = +/ /
解决办法
修改httpd.conf 将
EncodingEngine on
这一段配置移到需要的vitualHost里去,这个不能和php脚本并存。
下一篇: nginx做负载均衡配置
推荐阅读
-
给apache2.2加上mod_encoding模块後 php5.2.0 处理url出现bug_php技巧
-
给apache2.2加上mod_encoding模块後 php5.2.0 处理url出现bug
-
给apache2.2加上mod_encoding模块後 php5.2.0 处理url出现bug_php技巧
-
给apache2.2加上mod_encoding模块後 php5.2.0 处理url出现bug
-
给apache2.2加上mod_encoding模块後 php5.2.0 处理url出现bug_PHP教程
-
给apache2.2加上mod_encoding模块後 php5.2.0 处理url出现bug