加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 教程 > 正文

javascript操作referer详细步骤

发布时间:2023-10-26 15:26:11 所属栏目:教程 来源:
导读:Referrer的重要性

HTTP请求中有一个referer的报文头,用来指明当前流量的来源参考页。例如在www.sina.com.cn/sports/上点击一个链接到达cctv.com首页,那么就referrer就是www.sina.com.cn/sports/了。在Javascri
Referrer的重要性
 
HTTP请求中有一个referer的报文头,用来指明当前流量的来源参考页。例如在www.sina.com.cn/sports/上点击一个链接到达cctv.com首页,那么就referrer就是www.sina.com.cn/sports/了。在Javascript中,我们可以通过document.referrer来获取同样的信息。通过这个信息,我们就可以知道访客是从什么渠道来到当前页面的。这对于Web Analytics来说,是非常重要的,这可以告诉我们不同渠道带来的流量的分布情况,还有用户搜索的关键词等,都是通过分析这个referrer信息来获取的。
 
但是,出于各种各样的原因,有时候Javascript中读到的referrer却是空字符串。下面总结一下哪些情况下会丢失referrer。
 
修改Location对象进行页面导航
 
Location对象是一个用于页面导航的非常实用的对象。因为他允许你只变更Url的其中一部分。例如从cn域名切换到com域名,其他部分不变:
 
代码如下:
 
window.location.hostname = "example.com";
 
但是,通过修改Location进行页面导航的方法,会导致在IE下丢失Referrer。
 
IE5.5+ 下返回空字符串
 
Chrome3.0+,Firefox3.5,Opera9.6,Safari3.2.2均正常返回来源网页
 
window.open方式打开新窗口
 
示例:
 
代码如下:
 
<a href="#" onclick="window.open('http://www.google.com')">访问Google</a>
 
点击此链接会在新窗口打开Google网站,我们在地址栏中输入以下js代码就可以看到发送的referrer了。
 
代码如下:
 
javascript:alert(document.referrer)
 
测试结果:
 
IE5.5+ 下返回空字符串
 
Chrome3.0+,Firefox3.5,Opera9.6,Safari3.2.2均正常返回来源网页
 
如果是同个域名下通过此方式跳转的,那么我们可以通过访问windoww.opener对象去获取丢失的referrer信息。代码如下:
 
代码如下:
 
<script type="text/javascript">
 
    var referrer = document.referrer;
 
    if (!referrer) {
 
        try {
 
            if (window.opener) {
 
                // IE下如果跨域则抛出权限异常
 
                // Safari和Chrome下window.opener.location没有任何属性
 
                referrer = window.opener.location.href;
 
            }
 
        }
 
        catch (e) {}
 
    }
 
</script>
 
跨域的话则没辙了~
 
鼠标拖拽打开新窗口
 
鼠标拖拽是现在非常流行的用户习惯,很多浏览器都内置或者可以通过插件的方式来支持鼠标拖拽式浏览。但是通过这种方式打开的页面,基本全都丢失referrer。并且,这种情况下,也无法使用window.opener的方式去获取丢失的referrer了。
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章