ajax跨域理解

本文主要探讨了Ajax不能跨域的原因,是由于存在SOP(同源策略),浏览器会阻止不满足该策略的请求。Ajax请求过程中,浏览器会判断响应数据和请求是否同源,非同源则丢弃响应。解决Ajax跨域需服务器声明接受请求。

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

Ajax为啥不能跨域?

是因为存在SOP(同源策略)
如果Ajax请求的资源如果不满足SOP,浏览器就是禁用掉该请求。

Ajax跨域请求是被阻止的?
答案:浏览器
Ajax请求的过程:

Ajax会将请求提交到浏览器,浏览器再与服务器通信。
服务器将结果返回给浏览器,浏览器会判断服务器响应的数据和发出的请求是不是在同一个域下。
如果是,浏览器会将结果转交给Ajax请求;如果不是,浏览器会丢弃该响应数据。
所以,Ajax跨域是浏览器的一种自律行为。
如果,要解决Ajax跨域,需要服务器做出一个声明,告诉浏览器,尽管不在同一个域下,但这个请求我能接受,你(浏览器)放他过去吧。
在这里插入图片描述
在这里插入图片描述
解决方法(Nodejs例子):

//设置允许所有源都可以请求数据
res.setHeader('access-control-allow-origin', '*');

另外,如果需要跟安全,防止任何源都能请求服务器

//定义允许的请求源
let allowOrigin={
  'http://localhost': true
}

http.createServer((req, res)=>{
//通过req.headers获得请求源origin,检查是否在允许列表,如果存在,则给发送个*
  let {origin}=req.headers;
  if(allowOrigin[origin]){
    res.setHeader('access-control-allow-origin', '*');
  }
}).listen(8080);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值