美文网首页
[每天进步一点点~] 浏览器跨域问题

[每天进步一点点~] 浏览器跨域问题

作者: WYL_99 | 来源:发表于2020-09-05 20:56 被阅读0次

1. 什么是跨域?

跨域,是指浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的,是浏览器对JavaScript实施的安全限制。

同源策略限制了一下行为:

  • Cookie、LocalStorage 和 IndexDB 无法读取
  • DOM 和 JS 对象无法获取
  • Ajax请求发送不出去

1.1 同源策略

  • 所谓的 同源 是指,域名、协议、端口 均为相同。
  • 请求的url地址,必须与浏览器上的url地址处于同域上,也就是域名,端口,协议相同.
  • 只有在地址的: 协议名、域名、端口名
    相同的情况下,才允许访问相同的cookie、localStorage或是发送Ajax请求等等。
  • 若在不同源的情况下访问,就称为跨域。

1.2 协议

协议 即通信协议,比如我们现在常见的httphttps,如果当前页面地址使用 http 协议,请求的地址使用 https 协议,那么这个请求就存在跨域问题。

1.3 域名

域名 即网站网址,如 baidu.com,360.com 存在跨域。

1.4 端口号

端口号 即域名对应的服务器的监听端口,这个我们一般是看不到的,因为一般服务器都使用80端口,浏览器默认为80端口,所以不需要在域名后再写出端口号。当8080端口发出的请求为80端口时,也存在跨域。

2. 为什么会有跨域的问题?

跨域问题来源于浏览器的 同源策略,浏览器为了提高网站的安全性,在发送ajax请求时,只有在当前页面地址 与 请求地址的协议+域名+端口号相同时才允许访问,否则会被拦截。

这个就是同源策略的保护,如果浏览器对 javascript 没有同源策略的保护,那么一些重要的机密网站将会很危险。

3. 解决跨域的方法

3.1 jsonp 跨域

  • jsonp跨域 其实也是JavaScript设计模式中的一种代理模式。
  • 在html页面中通过相应的标签从不同域名下加载静态资源文件是被浏览器允许的,所以我们可以通过这个“犯罪漏洞”来进行跨域。
  • JSONP(是一种非正式传输协议),该协议的一个要点就是允许用户传递一个callback 参数给服务端。
  • 做法:一般,我们可以动态的创建script标签,再去请求一个带参网址来实现跨域通信。

举例:
http://study.cn/json/jsonp/jsonp_2.html下请求一个远程的js文件,代码如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
 
<script type="text/javascript">
    var message = function(data) {
        alert(data[1].title);
    };
</script>
 
<script type="text/javascript" src="http://web.cn/js/message.js"></script>
</head>
<body>
<div id='testdiv'></div>
</body>
</html>
// 或者另外 2 种写法
// 方法 1 :原生的实现方式,写在 js 中
let script = document.createElement('script');

script.src = 'http://www.nealyang.cn/login?username=Nealyang&callback=callback';

document.body.appendChild(script);

function callback(res) {
  console.log(res);
}

// 方法 2:jquery也支持jsonp的实现方式。缺点:只能发送get请求
$.ajax({
    url:'http://www.nealyang.cn/login',
    type:'GET',
    dataType:'jsonp',//请求方式为jsonp
    jsonpCallback:'callback',
    data:{
        "username":"Nealyang"
    }
})

远程的message.js文件是


image.png

这个时候我们得到的相应头是:


image.png
这样就实现跨域成功了。因为服务端返回数据时会将这个callback参数(message)作为函数名来包裹住JSON数据,这样客户端就可以随意定制自己的函数来自动处理返回数据了

资料地址:[ https://www.cnblogs.com/liubingyjui/p/10804785.html ]

3.2 CORS(跨域资源共享)

3.3 使用代理(如nginx)

相关文章

  • 解决跨域问题

    概述 在浏览器端进行 Ajax 请求时会出现跨域问题,那么什么是跨域,如何解决跨域呢?先看浏览器端出现跨域问题的现...

  • 跨域问题

    概述 在浏览器端进行 Ajax 请求时会出现跨域问题,那么什么是跨域,如何解决跨域呢?先看浏览器端出现跨域问题的现...

  • 跨域设置整理

    什么是跨域 不同域名之间相互请求资源,就是跨域。常说的跨域问题,指的是浏览器不允许跨域请求。这是由于浏览器的同源策...

  • Java跨域问题以及如何使用Cors解决前后端 分离部署项目所遇

    Java跨域问题以及如何使用Cors解决前后端 分离部署项目所遇到的跨域问题 什么是跨域 跨域,指的是浏览器不能执...

  • Chrome浏览器的跨域问题

    解决Chrome浏览器的跨域问题 对于前端来说,本地开发很经常会遇到跨域问题,最简单的方法就是将浏览器设置成可跨域...

  • ionic2/ionic1常见问题-跨域(No 'Acc

    问题描述 如下图所示,当我们的app请求后台服务时,就会出现浏览器跨域问题 什么是跨域 首先要明确,跨域是浏览器的...

  • ASP.NET Core笔试题 说说脚本在请求Web CoreA

    ### 说说脚本在请求Web CoreApi的时候,为什么会发生跨域问题? 跨域问题:本质是浏览器的行为,浏览器有...

  • [每天进步一点点~] 浏览器跨域问题

    1. 什么是跨域? 跨域,是指浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的,是浏览器对JavaScr...

  • 产生跨域的原因

    产生跨域的原因 浏览器的限制 跨域 XHR(XMLHttpRequest)请求 1、浏览器的限制 2、跨域 跨域概...

  • 前后端分离时解决跨域问题

    背景 : 前后端分离项目可能会存在跨域问题, 解决跨域问题的两种方法 一 :为什么存在跨域问题 浏览器的同源策略限...

网友评论

      本文标题:[每天进步一点点~] 浏览器跨域问题

      本文链接:https://www.haomeiwen.com/subject/sowfektx.html