我经常看到类似于这样的代码:
$PHP_SELF = $_SERVER['PHP_SELF'] ? $_SERVER['PHP_SELF'] : $_SERVER['SCRIPT_NAME']; 在网上查了很多的资料,说什么的都有,有说是PHP版本问题,php4.3.0以后PHP_SELF和SCRIPT_NAME就完全一样了,有说是服务器的解悉方式的问题造成了两者结果的不同。但就上面的代码而言我还是很不明白,
1. $_SERVER['PHP_SELF']在什么情况下会不存在?
2. $_SERVER[PHP_SELF]和$_SERVER[SCRIPT_NAME]在什么情况下会不相同?
$PHP_SELF = $_SERVER['PHP_SELF'] ? $_SERVER['PHP_SELF'] : $_SERVER['SCRIPT_NAME']; 在网上查了很多的资料,说什么的都有,有说是PHP版本问题,php4.3.0以后PHP_SELF和SCRIPT_NAME就完全一样了,有说是服务器的解悉方式的问题造成了两者结果的不同。但就上面的代码而言我还是很不明白,
1. $_SERVER['PHP_SELF']在什么情况下会不存在?
2. $_SERVER[PHP_SELF]和$_SERVER[SCRIPT_NAME]在什么情况下会不相同?
解决方案 »
- php 生成浏览器窗口缩略图怎么生成?
- 口啤网怎么做的?
- 都什么年代了还使那种好几个上传框上传图片
- smarty foreach 嵌套循环问题
- 一个frame如何关闭整个页面?
- 调查:PHP+AJAX大家一般用什么AJAX框架?
- 弄了个网站,方便大家找工作的,给点意见(留言有分)
- 自己的数据库连接类希望大家喜欢!其实其中几处可以再优化
- 教高手,何处可以下载apache_2.0.48-win32-x86-no_ssl.msi,我试过www.apeche.org,但没能找到,请高手指点
- win10安装好自带的iis后,仍无法运行php文件,希望高人解答,谢谢。
- preg_replace()Unknown modifier 'p'
- 向下兼容的写法?--关于一段php代码的疑惑
获得结果都一样
手册上说都是获得当前脚本名
而PHP_SELF 手册原话:从 PHP 4.3.0 版本开始,如果 PHP 以命令行模式运行,这个变量将包含脚本名。之前的版本该变量不可用。 如同二楼说的吧
“PHP_SELF”
当前正在执行脚本的文件名,与 document root 相关。举例来说,在 URL 地址为 http://example.com/test.php/foo.bar 的脚本中使用 $_SERVER['PHP_SELF'] 将会得到 /test.php/foo.bar 这个结果。__FILE__ 常量包含当前(例如包含)文件的绝对路径和文件名。
“SCRIPT_NAME”
包含当前脚本的路径。这在页面需要指向自己时非常有用。__FILE__ 包含当前文件的绝对路径和文件名(例如包含文件)。主要的原因如像:$_SERVER['PHP_SELF'] ? $_SERVER['PHP_SELF'] : $_SERVER['SCRIPT_NAME'];
找到更好的原因是:
今天在Dreamhost上安裝一套PHP程序時發現連接的地址都會多出一個cgi-system來,但是程序的config並沒有問題,查了查資料才發現是SCRIPT_NAME和PHP_SELF不同造成的問題。
通常在本機測試 $_SERVER['SCRIPT_NAME'] 跟 $_SERVER['PHP_SELF'] 大概看不出有什麼不同,因為大部分的PHP不是以CGI模式運行的。
但 DreamHost 上的 PHP 是以 CGI 方式運行,二者就有明顯不同的差異。
echo $_SERVER['SCRIPT_NAME']; // (/cgi-system/php.cgi)
echo $_SERVER['PHP_SELF']; // (/admin/test.php)从http://lists.nyphp.org/pipermail/talk/2005-July/015339.html 发现了一个说明。老外说的。SCRIPT_NAME solves all the problems mentioned
in this thread - it’s just the script name, without any extra garbage
that might be tacked on by the user. PHP_SELF explicitly includes that
extra garbage, so solutions in this thread that involve stripping the
garbage off of PHP_SELF to make it safe are really, really missing the
point - just use SCRIPT_NAME instead. Please don’t use FORM ACTION=”";
according to the spec, what the browser does with that is undefined, so
even if it works in current browsers, it might not work in future ones转自:http://www.cnblogs.com/5201314/archive/2009/05/18/1459134.html