js跨域

博客介绍了跨域的概念,即js在不同域间进行数据传输或通信。指出协议、端口、主机名不同会产生跨域问题,导致无法获取数据。还给出了两种解决方案,一是通过JSONP跨域,二是介绍了CORS请求原理,如在php中配置允许后台跨域。

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

跨域就是js在不同的域之间进行数据传输或者通信。

协议不同  端口不同 主机名不同 会产生跨域的问题,跨域意味着拿不到数据。

解决方案

1.通过JSONP跨域 也叫src跨域 ,通过给后台传递回调函数,来返回数据。

function addScriptTag(src) {
  var script = document.createElement('script');
  script.setAttribute("type","text/javascript");
  script.src = src;
  document.body.appendChild(script);
}
window.onload = function () {

  addScriptTag('http://example.com/ip?callback=foo');

}
function foo(data) {
  console.log('response data: ' + JSON.stringify(data));
};   

CORS 请求原理

  Cross-origin resource sharing  跨域资源共享。 php 允许后台跨域 在里面配置 header('Access-Control-Allow-Origin: * '); *代表允许所有域名都访问我。

var http = new XMLHttpRequest();
    http.open("post", "http://127.0.0.1:8080/0616/insert.php");
    http.send();
    http.onreadystatechange = function () {
        if (http.readyState == 4 && http.status == 200) {
            console.log(http.response);
        }
    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值