Ajax跨域获取数据的简便方法

本文介绍了如何通过在服务器端创建一个代理页面解决Ajax跨域问题。当浏览器的同源策略限制了Ajax请求,可以使用代理页面将请求转发到目标域,再将数据返回给客户端。例如,将原本的请求改向代理页面redirect.aspx,该代理页负责转发所有请求参数。这种方法相比直接使用服务器端的xmlhttp对象更便捷。需要注意的是,代理页需要处理POST请求的参数传递。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

跨域通信的限制是在浏览器端,也就是客户端上,所以可以从服务器端代码做文章。这和前几天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);

这其实比服务器端是用xmlhhtp还方便。

btw:IE限制跨域的地方在

工具-Internet选项-安全-自定义级别-通过域访问数据源-禁用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值