前端跨域问题复现代码

直接引用,修改接口地址及传参即可
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>

<body>
  <button id="submit">jsonp请求</button>
  <script>
    // 将来后端返回的数据用形参data接收
    function getName(data) {
      console.log(data);

    }
    document.querySelector('#submit').onclick = function () {
      console.log('ok');
      // 尝试1:失败,无法访问,因为跨域了
      var xhr = new XMLHttpRequest()
      xhr.open('post', 'http://127.0.0.1:8009/test')
      xhr.setRequestHeader('Content-Type', 'application/json;charset=UTF-8')
      xhr.send(JSON.stringify({
          "name": "admin",
          "password": "admin"
      }))
      xhr.onload = function () {
        console.log(xhr.responseText);
      }
      

      // 尝试2:jsonp原理实现跨域,成功
      // var newscript = document.createElement('script')
      // newscript.setAttribute('src', 'http://localhost:9999/index?callback=getName')
      // document.body.appendChild(newscript)

    }
  </script>
  <!-- <script src="http://localhost:9999/index?callback=getName"></script> -->
</body>

</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值