转载:www.5idev.com/p-php_serve…
使用 $_SERVER['HTTP_REFERER'] 将很容易得到链接到当前页面的前一页面的地址。一个例子如下:
index.php(实际地址为:www.5idev.com/php/index.p…
链接 test.php(实际地址为:www.5idev.com/php/test.ph…
echo $_SERVER['HTTP_REFERER']; 在浏览器访问 index.php,点击链接到 test.php,得到的输出结果为:
www.5idev.com/php/index.p… PHP _SERVER['HTTP_REFERER'] 完全来源于浏览器。并不是所有的用户代理(浏览器)都会设置这个变量,而且有的还可以手工修改 HTTP_REFERER。因此,$_SERVER['HTTP_REFERER'] 不总是真实正确的。
通常下面的一些方式,$_SERVER['HTTP_REFERER'] 会无效:
直接输入网址访问该网页。 Javascript 打开的网址。 Javascript 重定向(window.location)网址。 使用 meta refresh 重定向的网址。 使用 PHP header 重定向的网址。 flash 中的链接。 浏览器未加设置或被用户修改。 所以一般来说,只有通过 超链接以及 POST 或 GET 表单访问的页面,$_SERVER['HTTP_REFERER'] 才有效。
由于_SERVER['HTTP_REFERER'] 来防止表单数据的恶意提交。但该方法并不能保证表单数据的绝对正确,即对表单数据的真实性检测并不能完全依赖于 $_SERVER['HTTP_REFERER'] 。