引言:在使用原生PHP的时候,对于URL路径的切割,如:域名,查询参数等等的提取,通常绝大多数兄弟会忽略$_SERVER中定义的内置常量的关系,这里为大家讲解一下。
常用的URL请求路径$_SERVER常量包含以下四个API!
- $_SERVER["SCRIPT_NAME"] 获取当前脚本的路径,如:index.php
- $_SERVER["PHP_SELF"] 当前正在执行脚本的文件名
- $_SERVER["QUERY_STRING"] 获取查询语句,实例中可知,获取的是?后面的值
- $_SERVER["REQUEST_URI"] 获取http://blog.snsgou.com后面的值,包括/
如果不直观,大家继续看下面的示例,有详细解释!
示例讲解
示例1:
网址:http://do.org.cn/ (直接打开主页)
输出结果:
$_SERVER["SCRIPT_NAME"] = "/index.php" $_SERVER["PHP_SELF"] = "/index.php" $_SERVER["QUERY_STRING"] = "" $_SERVER["REQUEST_URI"] = "/"
示例2:
网址:http://do.org.cn/?p=1 (附带查询)
输出结果:
$_SERVER["SCRIPT_NAME"] = "/index.php" $_SERVER["PHP_SELF"] = "/index.php" $_SERVER["QUERY_STRING"] = "p=1" $_SERVER["REQUEST_URI"] = "/?p=1"
示例3:
网址:http://do.org.cn/index.php?p=1&q=superdo
输出结果:
$_SERVER["SCRIPT_NAME"] = "/index.php" $_SERVER["PHP_SELF"] = "/index.php" $_SERVER["QUERY_STRING"] = "p=1&q=superdo" $_SERVER["REQUEST_URI"] = "/index.php?p=1&q=superdo"
示例4:
网址:http://do.org.cn/123/123.php/abc/def?id=1&name=ac
输出结果:
$_SERVER["SCRIPT_NAME"] = "/123/123.php" $_SERVER["PHP_SELF"] = "/123/123.php/abc/def" $_SERVER["QUERY_STRING"] = "id=1&name=ac" $_SERVER["REQUEST_URI"] = "/123/123.php/abc/def?id=1&name=ac"
示例5:
网址:http://do.org.cn/123/123.php/abc/def.bat?id=1&name=ac
输出结果:
$_SERVER["SCRIPT_NAME"] = "/123/123.php" $_SERVER["PHP_SELF"] = "/123/123.php/abc/def.bat" $_SERVER["QUERY_STRING"] = "id=1&name=ac" $_SERVER["REQUEST_URI"] = "/123/123.php/abc/def.bat?id=1&name=ac"
经验之谈:
总结一下,对于SCRIPT_NAME、PHP_SELF、QUERY_STRING、REQUEST_URI,深入了解将有利于我们 在$_SERVER函数中正确调用这四个值。
一般地: $_SERVER["REQUEST_URI"] = $_SERVER["PHP_SELF"] . ‘?‘ . $_SERVER["QUERY_STRING"]
注意
注意:当有地址重写时,情况有些变化,例如:
/class 重写到 /index.php?app=class&mod=Index&act=index
此时:
$_SERVER[‘PHP_SELF‘] 值等于 /index.php
$_SERVER[‘QUERY_STRING‘] 值等于 /index.php?app=class&mod=Index&act=index
$_SERVER["REQUEST_URI"] 值等于 /class
相关代码
uchome系统中处理技巧:
// 处理REQUEST_URI if (!isset($_SERVER[‘REQUEST_URI‘])) { $_SERVER[‘REQUEST_URI‘] = $_SERVER[‘PHP_SELF‘]; if (isset($_SERVER[‘QUERY_STRING‘])) $_SERVER[‘REQUEST_URI‘] .= ‘?‘ . $_SERVER[‘QUERY_STRING‘]; } if ($_SERVER[‘REQUEST_URI‘]) { $temp = urldecode($_SERVER[‘REQUEST_URI‘]); if (strexists($temp, ‘<‘) || strexists($temp, ‘"‘)) { $_GET = shtmlspecialchars($_GET); // XSS } }
结束语
这里介绍了一下$_SERVER的关于<URL路径>的常量的解惑,其他的常量还非常多,待稍后有机会再归类给大家进行讲解。
未完,待更新...
本站文章为宝宝巴士 SD.Team原创,转载务必在明显处注明:(作者官方网站:宝宝巴士)
转载自【宝宝巴士SuperDo团队】 原文链接: http://www.cnblogs.com/superdo/p/4822676.html