跨域通信的限制是在浏览器端,也就是客户端上,所以可以从服务器端代码做文章。这和前几天gzip的问题很相像了,当时服务器上的gzip流是因为被isa阻止而无法下载压缩后的文件,最后写了一个压缩代理放在服务器上,强制返回压缩数据。
现在这个问题最简便的方法也是写一个代理来把js请求的数据从另外一个域转发到本域,然后再用js访问代理。
比如代码:
obj.sendRequest("http://www.abc.com/test.aspx?p1=tt&p2=sss");
将变为
obj.sendRequest("redirect.aspx?url=http%3A%5C%5Cwww.abc.com%5Ctest.aspx%3Fp1%3Dtt%26p2%3Dsss
其中redirect.aspx就是转发代理,考虑到obj对象有些参数可能是post上来的,应该在这个代理页的服务器端要把所有的request参数传给请求页面,下面的示例省略了这一步。aspx的转发代理的代码很简单
System..Net.WebClient wb=new System.Net.WebClient();
byte[] b=wb.DownLoadData(Request["Url"]);
Response.BinaryWrite(b);
byte[] b=wb.DownLoadData(Request["Url"]);
Response.BinaryWrite(b);
这其实比服务器端是用xmlhhtp还方便。
btw:IE限制跨域的地方在
工具-Internet选项-安全-自定义级别-通过域访问数据源-禁用