页面调用iframe,网站配置到服务器上之后,iframe部分的内容无法加载

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了页面调用iframe,网站配置到服务器上之后,iframe部分的内容无法加载相关的知识,希望对你有一定的参考价值。

是无法加载还是看不到iframe里面的内容,是不是iframe或者iframe里面的内容没有定义宽度或者高度? 参考技术A 是不是路径问题 参考技术B 可能是跨域问题,建议检查下url的路径

iframe 中的 iframe 不会加载

【中文标题】iframe 中的 iframe 不会加载【英文标题】:iframe in iframe won't load 【发布时间】:2013-01-06 20:51:12 【问题描述】:

我遇到了一些跨域 iframe hack 的问题。

我的页面上有一个 iframe“if1”,其中包含另一个 iframe“if2”。

“顶部”页面在域 A 上运行。 if1 的页面在域 B 上运行。 而if2的页面是在域A上运行的。

我想要做的是:在 if1 中运行身份验证,将结果令牌作为哈希传递给 if2 的 url 并加载 if2。当加载 if1 的页面时,令牌已经通过身份验证,我只是添加了 if2 和已经生成的 url,如下所示:

<iframe name="if2" id="if2" src="http://example.com/testing#token=8927348962028" onload="javascript:alert('loaded');" onerror="javascript:alert('unable to load iframe');" ></iframe>

现在,if2 根本不加载,它只是保持白色。我总是收到“无法加载 iframe”的警报。 但这仅在 if1 嵌入“顶部”页面时发生。当我在浏览器的另一个选项卡中简单地加载 if1 的内容时,if2 加载完美。

是否有一些政策可以阻止加载二级 iframe?还是我错过了什么?

【问题讨论】:

它应该工作,我得到loaded 两次:fiddle。此外,框架仅显示其内容。 @Rune:好吧,看起来很安静,但是问题是否仅在您拥有域 A -> 域 B -> 域 A 时才会出现?因为据我所知,您的示例具有以下结构:域 A -> 域 A -> 域 B 你能给一个包含 iframe 的网站的链接吗?这样我就可以测试 A > B > A。 hm,我试过这个fiddle 在小提琴上插入 iframe 代码时似乎不起作用。 iframe 是白色的。当我保存小提琴(页面重新加载)时,内部 iframe 已加载。 我认为浏览器意识到如果他加载了 if2 它将是一个循环(因为 if2 也加载了 if1 ...)。我仍在测试,但这可能是问题所在。 【参考方案1】:

我找到了解决问题的方法。

如果您使用加载页面 B 的 iframe 加载页面 A,并且在其中再次加载页面 A 的 iframe,则您有一个循环,导致页面 A 加载页面 B 等等。

在我的情况下,浏览器停止加载第二个 iframe(再次加载页面 A 的 iframe)。 这似乎是防止这种循环的正常行为。

我只是在 if2 的 url 中添加了一个 ?innerframe=true 参数,并在设置该参数时阻止了 if1 的加载。这样循环消失了,问题也消失了。

@Rune:感谢您的帮助,fiddle 的链接对解决这个问题非常有帮助。

【讨论】:

?innerframe=trueJavaScript?如果没有,请发布您的 iframe 代码! 这似乎是一个查询参数 如前所述,我将其添加到 url。所以它是一个 HTTP GET 参数。

以上是关于页面调用iframe,网站配置到服务器上之后,iframe部分的内容无法加载的主要内容,如果未能解决你的问题,请参考以下文章

<iframe>嵌套打开自己网站的页面失败,求解决方法

如何防止我的网站页面被加载到其他网站的 iframe 中?

iframe 何时开始加载到页面上?

想利用jquery 改变 跨域 iframe 中的内容样式 该怎么做呢?

js如何判断是否在iframe中/JQuery调用iframe父页面元素与方法

IFRAME 中的 AJAX 调用