ITKeyword,专注技术干货聚合推荐

注册 | 登录

解决IFrame跨域以及Ajax跨域的问题

hack8 分享于 2009-04-20

推荐:关于AJAX跨域调用ASP.NET MVC或者WebAPI服务的问题及解决方案

问题描述 当跨域(cross domain)调用ASP.NET MVC或者ASP.NET Web API编写的服务时,会发生无法访问的情况。 重现方式 使用模板创建一个最简单的ASP.NET Web API

2018阿里云全部产品优惠券(新购或升级都可以使用,强烈推荐)
领取地址https://promotion.aliyun.com/ntms/yunparter/invite.html?userCode=82lei0yp

最近做了一个网站,结果老板说我们这个网站将来会有很多其他的网站以IFRAME的方式嵌入到他们自己的网站内部使用,但是别人利用IFRAME嵌入后根本就没有办法使用我们的网站,比较郁闷,老板让赶紧解决。

通过在网络上搜索相关的资料发现如下几个文章不错

推荐:解决同域Nginx ajax 请求跨域的问题

在nginx.conf的根server  location上添加如下配置 location / { if ($request_method = 'OPTIONS') { add_header 'Access-Control-Allow-Origin' '*';

http://www.cnblogs.com/BillChen/archive/2008/11/03/814079.html

上面这个文章解决了我的Ajax跨域问题

解决ASP.NET AJAX在frame及iframe中跨域访问的问题

参考网址:
http://support.microsoft.com/kb/936993/zh-cn
http://weblogs.asp.net/bleroy/archive/2007/01/31/how-to-work-around-the-quot-access-denied-quot-cross-domain-frame-issue-in-asp-net-ajax-1-0.aspx
http://blogs.msdn.com/delay/archive/2007/02/05/safely-avoiding-the-access-denied-dialog-how-to-work-around-the-access-denied-cross-domain-iframe-issue-in-the-ajax-control-toolkit.aspx
http://www.cnblogs.com/jackielin/archive/2007/02/07/643411.html

1、为ScriptManager添加脚本引用,不从ScriptResource.axd中加载MicrosoftAjax.js脚本,而是直接加载

     < asp:ScriptManager  ID ="ScriptManager1"  runat ="server"  EnablePageMethods ="true" >
         < Scripts >
            <asp:ScriptReference Name="MicrosoftAjax.js" ScriptMode="auto" Path="~/ScriptLibrary/System.Web.Extensions/1.0.61025.0/MicrosoftAjax.js" />
         </ Scripts >
     </ asp:ScriptManager >
2、修改MicrosoftAjax.debug.js
删除
switch (Sys.Browser.agent)  {
    case Sys.Browser.InternetExplorer:与
case  Sys.Browser.Safari: 之间的脚本,替换为如下脚本:
Sys.UI.DomElement.getLocation  =   function (element)  {
    if (element.self || element.nodeType === 9) return new Sys.UI.Point(0,0);
    var clientRect = element.getBoundingClientRect();
    if (!clientRect)  {
        return new Sys.UI.Point(0,0);
    }
    var ownerDocument = element.document.documentElement;
    var offsetX = clientRect.left - 2 + ownerDocument.scrollLeft,
        offsetY = clientRect.top - 2 + ownerDocument.scrollTop;
    
    try  {
        var f = element.ownerDocument.parentWindow.frameElement || null;
        if (f)  {
            var offset = 2 - (f.frameBorder || 1) * 2;
            offsetX += offset;
            offsetY += offset;
        }
    }
    catch(ex)  {
    }    
    
    return new Sys.UI.Point(offsetX, offsetY);
}
break ;

3、修改MicrosoftAjax.js
删除
switch (Sys.Browser.agent) {case Sys.Browser.InternetExplorer:与
case  Sys.Browser.Safari: 之间的脚本,替换为如下脚本:
Sys.UI.DomElement.getLocation = function (a) {if(a.self||a.nodeType===9)return new Sys.UI.Point(0,0);var b=a.getBoundingClientRect();if(!b)return new Sys.UI.Point(0,0);var c=a.document.documentElement,d=b.left-2+c.scrollLeft,e=b.top-2+c.scrollTop;try {var g=a.ownerDocument.parentWindow.frameElement||null;if(g) {var f=2-(g.frameBorder||1)*2;d+=f;e+=f}}catch(h) {}return new Sys.UI.Point(d,e)} ; break ;  
下载 另外一篇文章是介绍如何在IFrame中实现跨域Cookie的问题,利用这两篇文章顺利解决了我面临的问题,感谢,感谢。

推荐:JAX-RS开发(三):ajax访问REST服务时的跨域问题以及jsonp解决方案

同源策略是指:协议、主机和端口都相同。我们可以在本地机器上部署2个不同端口的tomcat,让一个tomcat下的应用通过ajax访问另一个tomcat下的rest服务,这样就存

最近做了一个网站,结果老板说我们这个网站将来会有很多其他的网站以IFRAME的方式嵌入到他们自己的网站内部使用,但是别人利用IFRAME嵌入后根本就没有办法使用我们的网站,比较郁闷,老板让赶紧

相关阅读排行


用户评论

游客

相关内容推荐

阿里云RDS

最新文章

×

×

请激活账号

为了能正常使用评论、编辑功能及以后陆续为用户提供的其他产品,请激活账号。

您的注册邮箱: 修改

重新发送激活邮件 进入我的邮箱

如果您没有收到激活邮件,请注意检查垃圾箱。