多次重定向中http-referer的变化
基本概念
先初步了解下URL重定向,Http Referer两个概念
URL重定向(URL redirection,或称网址重定向或网域名称转址),是指当使用者浏览某个网址时,将他导向到另一个网址的技术。
说白了就是URL重定向就是把一个URL重新定向到另一个URL上去,重定向可以把一个目录或者文件的访问请求转发至另外一个目录或者文件。
HTTP Referer是header的一部分,当浏览器向web服务器发送请求的时候,一般会带上Referer,告诉服务器我是从哪个页面链接过来的,服务器籍此可以获得一些信息用于处理。
也就是说,比如从百度搜索找到这篇文章后,用户点击访问到这篇文章,那么我就能够从HTTP Referer中统计出每天有多少用户访问我这个页面来自于百度。
HTTP Referer 获取
在ASP中获取Referer
的方式是:Request.ServerVariables("HTTP_REFERER");
在JSP中获取Referer
的方式是:request.getHeader("REFERER");
在PHP中获取Referer
的方式是:$_SERVER['HTTP_REFERER'];
下列情况是能取得到Referer
:
- 使用
a
标签访问页面<a href="http://www.appblog.cn/">点击这里</a>
- 使用JavaScript点击事件访问页面
<a href="#" onclick='window.location.href="referer.php";return false;'>点击这里</a>
- 用Submit input提交的表单(POST or GET)
- 使用JavaScript提交的表单(POST or GET),其实与2类似。
- 使用JavaScript重定向:
location.href
重点是这个,下列情况是取不到Referer
:
- 从收藏夹点击链接,浏览器自定义主页打开或是在浏览器上手动输入http地址
- 使用服务器语言重定向,如
ASP: Response.Redirect
PHP: header('Location: ')
- 使用HTTP重定向方式,如302重定向
- 使用JavaScript重定向:
location.replace()
- 用XML加载地址
HTTP Referer 传递
关于二次以上重定向,保存Referer
的方式。
举一个例子,倘若我们的一个链接已经被百度或者谷歌收录了,如:
http://www.baidu.com/s?wd=appblog.cn
记为:搜索页
找到一条自己网站的页面
http://www.appblog.cn/shopping.php
记为:页面A
而此时我们这个页面可能已经不需要了,这时候我们需要重定向到我们的一个淘宝主页:如:
http://me1.taobao.com/
记为:页面B
上述过程可以看做为二次重定向。
根据上面所说的情况,在页面A是可以找到Referer
,这个Referer
就是搜索页,当重定向到页面B上的时候,我们会发现页面B得到的Referer
其实也是搜索页。
对此找到的解释为:大部分浏览器的行为。
但根据上述Referer
不能获取的情形,如 HTTP 302 重定向方式就无法获取到Referer
,参考:
http://stackoverflow.com/questions/2158283/will-a-302-redirect-maintain-the-referer-string
因此不能过分的依赖Referer
,如要正确的获得这个Referer
,可以在页面A中把Referer
作为参数,从地址栏中传递到下个面。如
$url = 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];
$url = base64_encode($url);
header ('Location: http://www.taobao.com/?referer='.$url);
版权声明:
作者:Joe.Ye
链接:https://www.appblog.cn/index.php/2023/03/25/changes-in-http-referer-during-multiple-redirects/
来源:APP全栈技术分享
文章版权归作者所有,未经允许请勿转载。
共有 0 条评论