关于JS跨域的解决方案

ajax下的xmlHttp 在A域名下请求B域名下的服务,会发生js跨域的问题,研究了网上的解决方案,最后找到一个合适的,分享一下:

问题:

在a.project.com域名下,客户端的js上传文件到b.project.com域名下的服务器,产生跨域问题,

完美解决方案:

1、在b.project.com域下添加ajax.html文件,添加到网站根目录
内容:

<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>Untitled Page </title>
    <script type="text/javascript" language="javascript">
        document.domain = "*.project.com";
        
        function getHttpRequest(){
        	var xmlHttp;
        	if (window.XMLHttpRequest) {
				xmlHttp = new XMLHttpRequest();
				return xmlHttp;
			} else if (window.ActiveXObject) {
				try {
					xmlHttp = new ActiveXObject("MSXML2.XMLHTTP");
					return xmlHttp;
				} catch (e) {
					try {
						xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
						return xmlHttp;
					} catch (e) {
						alert("不能创建XmlHttp");
						return null;
					}
				}
			}
			return xmlHttp;
		}
    </script>
</head>
<body>
</body>
</html>
2、在a.project.com域名下的jsp上,同样将domain设置为 document.domain = "*.project.com";然后添加iframe:

<iframe src="http://upload.docin.com/ajaxdomainproxy.html" id="postiframe" width="0" height="0" style="display:none"></iframe>

3、发起请求的时候,调用postiframe下的getHttpRequest()方法,获得XMLHttpRequest,即可。

获取方法:

function getXmlHttpObj(){
    var proxy = document.getElementById("postiframe").contentWindow;
    return proxy.getHttpRequest();
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值