我们经常使用 HTML target="_blank" 或 window.open() 在新窗口打开页面。
然而,当新打开的页面指向一个我们不知道的网站时,我们将暴露在钓鱼网站的漏洞中。新页面通过 window.opener对象获得了部分访问链接页面的权限。
例如,可以使用 window.opener.location 将初始页面的用户指向一个虚假的钓鱼网站,模仿原始网站的外观,做各种恶心的事情。这可能对用户信任已经打开的页面非常有效。
为了防止这种情况,我们可以:
在 HTML 中使用 rel="noopener 和 target="_blank"。
在Javascript一定要重置 opener 属性:
后续:现在看来,noreferrer 是多余的,所以noopener` 对于HTML使用应该足够。
作者:Daniel 译者:前端小智
来源:js-craft 原文:http://www.js-caft.io/blog/window-open-and-target_blank-have-a-security-vulnerability/