gpt4 book ai didi

javascript - 可以获取iframe的url跨域吗?

转载 作者:行者123 更新时间:2023-11-28 00:57:00 25 4
gpt4 key购买 nike

如果是跨域 iframe,如何在页面加载时获取 iframe 的当前 url?

背景 - 我正在尝试在我的网站上启用 SSL。但是,我的用户需要能够通过 iframe 加载任何 url。如果他们尝试使用 http 协议(protocol)加载 iframe,它将拒绝加载,因为父页面是 https。

我想自动检测 iframe 是否为 http - 如果是,则将父页面重定向到 http。但是,使用我尝试过的任何方法,我在访问时都会遇到 CORS 错误。

这是我的 iframe:

<iframe id="myframe" src='https://apple.com' onload="this.contentWindow.parent.postMessage(this.contentWindow.document.location.protocol, parent.document.location);" width="800" height="600">
</iframe>

这是我的事件监听器:

window.addEventListener("message", receiveMessage, false);
function receiveMessage(event) {
console.log(event.data)
}

我能够接收纯字符串作为消息,但我无法接收协议(protocol)。我使用 window.postMessage() 的结果是一个 CORS 错误,我认为它应该允许跨域通信。

最佳答案

不可能,出于安全原因,您无法访问其他域/主机/端口内容或 iframe 的 src url

关于javascript - 可以获取iframe的url跨域吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44291523/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com