位置: 编程技术 - 正文

JavaScript中的document.referrer在各种浏览器测试结果(javascript中的document.write)

编辑:rootadmin

推荐整理分享JavaScript中的document.referrer在各种浏览器测试结果(javascript中的document.write),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript中的document对象,javascript中的document对象,javascript中的document w,javascript中的document,javascript中的document对象,javascript中的document.write,javascript中的document的方法,javascript中的document的方法,内容如对您有帮助,希望把文章链接给更多的朋友!

前段时间需要通过 JavaScript 获取页面的来源,这个操作很简单,使用 document.referrer 就可以获取到了。不过,实际应用中还是有很多意外情况,这儿简单整理一下。

首先遇到的问题,是从 HTTPS 页面转到 HTTP 页面后,document.referrer 的值为空。出于安全性考虑,很多网站的一些重要页面(比如淘宝的登录页面)都会使用 HTTPS 协议。如果某个未登录用户在页面 A(HTTP 页面)点击了页面 B(HTTP 页面)的链接,但页面 B 需要用户登录,于是先跳到登录页面 (HTTPS 页面),登录完成之后再跳回 B(HTTP 页面),这时你会发现 B 页面上取不到 document.referrer 了。也就是说,如果想根据 referrer 来还原用户访问路径的话,如果路径中有 HTTP 页面也有 HTTPS 页面,那么这个路径就会在从 HTTPS 到 HTTP 的地方断掉。

这个问题的根源是浏览器的安全策略,只靠 JavaScript 似乎没有特别好的解决办法。一个迂回的思路是使用 window.name,在 HTTPS 页面将当前页面的 url 写到 window.name 中,再在下一个页面(HTTP 页面)读取。

除了这种情况,其它页面跳转是否都能正常取到 document.referrer 呢?我搜索了一番,发现 这儿 有人整理了一个列表,不过不是很全,例如没有包括垂而不死的 IE6 的情况。于是便自己动手,在虚拟机里装了 N 个浏览器,把各种情况都测试了一下(这真是一个体力活),结果见下表:

操作 IE6 IE7 IE8 IE9 Firefox Chrome Opera Safari 直接在地址栏输入URL “” “” “” “” “” “” “” “” 从书签访问URL “” “” “” “” “” “” “” “” 从页面A点击超链接,跳转到页面B(target=”_self”) √ √ √ √ √ √ √ √ 从页面A点击超链接,跳转到页面B(target=”_blank”) √ √ √ √ √ √ √ √ 从页面A右键单击超链接,在新标签页中打开页面B - √ √ √ √ √ √ “” 从页面A右键单击超链接,在新窗口中打开页面B √ √ √ √ √ √ √ “” 拖动链接到地址栏 “” 无法拖动 无法拖动 “” “” “” “” “” 拖动链接到标签栏 - “” “” “” “” “” “” “” 使用浏览器的前进、后退按钮 √ √ √ √ √ √ √ √ JS 修改 location.href “” “” “” √ √ √ √ √ JS 使用 window.open “” “” “” “” √ √ √ √ 服务器重定向(跳转) 定向之前的页面 定向之前的页面 定向之前的页面 定向之前的页面 定向之前的页面 定向之前的页面 定向之前的页面 定向之前的页面 页面 Meta Refresh “” “” “” “” “” 转向页 转向页 转向页

JavaScript中的document.referrer在各种浏览器测试结果(javascript中的document.write)

上表中的“√”表示能正常取到 referrer,”” 表示 referrer 为空。

除了 IE 外,其它浏览器都是目前官网上能下载到的最新版本,其中 Safari 同时测试了 Windows 版和 Mac 版,结论一样。

另外还有一些情况未做测试,例如点击 Flash 跳转时各浏览器下能否保持 referrer 等。

上表中大部分情况是符合预期的,不过似乎也有几处需要注意的:

1、在 Safari 中,右键打开链接会丢失 referrer;2、在 IE 中,修改 location.href 或使用 window.open 打开页面会丢失 referrer(IE 9 有一点例外,使用 location.href 跳转不会丢失 referrer);3、使用 meta 跳转时,IE / Firefox 下会丢失 referrer。

最后,一个简单的结论是:如果你需要通过 document.referrer 采集页面访问来源,最好不要使用 JS 跳转或打开新窗口,也不要使用 meta 跳转。

javascript定义变量时有var和没有var的区别探讨 我们先来看一段代码functionshow(){alert(abc);}varabc="defg";show();有过C++或Java编程经验的人可能会说:这程序,死定了,变量竟然在引用了该变量的函数后边定

javascript中声明函数的方法及调用函数的返回值 htmlxmlns="

JavaScript匿名函数与委托使用示例 htmlxmlns="

标签: javascript中的document.write

本文链接地址:https://www.jiuchutong.com/biancheng/370176.html 转载请保留说明!

上一篇:js 模式窗口(模式对话框和非模式对话框)的使用介绍(js设置窗口位置)

下一篇:javascript定义变量时有var和没有var的区别探讨(javascript如何定义变量)

  • 发放上年年终奖个税
  • 增值税认证勾选平台
  • 增值税专票开户行
  • 个人所得税减除费用6万元什么意思
  • 端午节福利计入什么科目
  • 发票勾选平台怎么导出未勾选的发票
  • 资产减值损失在利润表怎么填列
  • 退休回聘政策与程序
  • 各部门发生的医保费用
  • 购买车间用的材料怎么做分录
  • 股票持有多久可以打新股
  • 生产企业报关单金额大于发票金额
  • 无形资产怎么衡量
  • 计提长期借款利息会计分录
  • 研发支出是否可以抵税
  • 返利冲减销售收入还是进费用
  • 扣缴义务人申报和综合所得年度自行申报
  • 如何在windows11上安装动态壁纸
  • 认缴出资额日期没有是什么意思
  • php初学者常见问题和答案
  • 提前退休的一次性补贴收入
  • php的数组函数
  • 企业重组税收政策汇编
  • 建筑安装发票可以外地开吗
  • 阿尔比恩洞的级别
  • 前端项目如何部署到服务器
  • “普罗旺斯”
  • 青龙面板库怎么用
  • 背景渐变 css
  • 支付价款含不含增值税
  • 低值易耗品管理办法
  • 一直暂估原材料有什么风险
  • 增值税专用发票和普通发票的区别
  • 简易征收适用哪些业务租赁
  • 取得投资是什么意思
  • 合伙开网吧需要什么手续
  • 接受捐赠计入
  • 本年利润会计处理流程
  • 居民和非居民企业的区别是什么
  • 利润表中的所得税费用包括哪些
  • 公司基建维修承诺书
  • 长期股权投资损益调整
  • 营改增后众筹融资业务的会计处理分析?
  • 小规模纳税人免税政策2023年
  • 无形资产的处置方式有哪些
  • 暂估出库需要确认收入吗
  • 母公司与子公司的区别
  • 会计人员基本信息表去哪找
  • 项目资本金如何确定
  • 公认会计原则是哪个国家的?
  • 转出未交增值税借方余额表示什么
  • 企业货币资金主要包括哪些
  • ubuntu怎么修改网络配置
  • mac装双系统后无法开机
  • linux系统中用户可以分为三种
  • qq2440启动linux后插入u盘出现usb 1-1: device descriptor read/64, error -110,usb 1
  • 在win8下能直接装win7吗
  • win8系统映像
  • linux ssh安装包
  • win10开始菜单什么样子
  • opengl数据类型
  • 帝国cms列表页隐藏部分文章
  • 不错的意思
  • html竖排改为横排
  • 简述python语言
  • nodejs怎么学
  • pyqt用法
  • angular jsx
  • ecmascript6 官方文档
  • jquery树形菜单
  • linux 中的atq命令
  • javascript的几种数据类型
  • js跨域的几种方法
  • fragment生命周期图
  • python的入门教程
  • 开票税额超出1万怎么办
  • 国家税务总局河北地税局
  • 辽宁地方税务网站官网
  • 车辆购置税去哪个税务局交
  • 曲靖注册公司要哪些条件
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设