首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >拒绝在帧中显示,因为它将“X帧选项”设置为“SAMEORIGIN”

拒绝在帧中显示,因为它将“X帧选项”设置为“SAMEORIGIN”
EN

Stack Overflow用户
提问于 2013-12-10 15:45:48
回答 21查看 994.4K关注 0票数 334

我正在开发一个网站,应该是响应,以便人们可以访问它从他们的手机。该网站拥有一些安全部件,可以使用谷歌、Facebook、...etc (OAuth)登录。

服务器后端是使用ASP.Net Web 2开发的,前端主要是带有Razor的AngularJS。

对于身份验证部分,所有浏览器(包括Android )都运行良好,但Google身份验证在iPhone上不起作用,它给我提供了以下错误信息:

代码语言:javascript
复制
Refused to display 'https://accounts.google.com/o/openid2/auth
?openid.ns=http://specs.openid.ne…tp://axschema.org/namePerson
/last&openid.ax.required=email,name,first,last'
in a frame because it set 'X-Frame-Options' to 'SAMEORIGIN'.

现在,在我的HTML文件中,我不使用任何iframe。

我搜索了一下,但没有任何答案让我解决了这个问题。

EN

回答 21

Stack Overflow用户

回答已采纳

发布于 2013-12-12 03:42:34

好吧,在这件事上花了更多的时间之后,所以把它贴出来

Overcoming "Display forbidden by X-Frame-Options"

我设法解决了这个问题,在发布到google之前将&output=embed添加到url的末尾:

代码语言:javascript
复制
var url = data.url + "&output=embed";
window.location.replace(url);
票数 107
EN

Stack Overflow用户

发布于 2014-11-06 15:59:39

我找到了一个更好的解决方案,也许它可以帮助别人用"v/"代替"v/",这样会奏效的。

代码语言:javascript
复制
var url = url.replace("watch?v=", "v/");
票数 178
EN

Stack Overflow用户

发布于 2015-11-18 10:45:10

在本例中,它们将头设置为SAMEORIGIN,这意味着它们不允许在其域中以外的iframe中加载资源。因此,此iframe无法显示跨域。

为此,您需要匹配apache或任何其他正在使用的服务中的位置。

如果您正在使用apache,那么在httpd.conf文件中。

代码语言:javascript
复制
  <LocationMatch "/your_relative_path">
      ProxyPass absolute_path_of_your_application/your_relative_path
      ProxyPassReverse absolute_path_of_your_application/your_relative_path
   </LocationMatch>
票数 48
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20498831

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档