前端跨域
跨域是指一个域下的文档或脚本试图去请求另一个域下的资源。也就是说如果协议,域名,或者端口有一个不同就是跨域。 那么为什么要用跨域? 其实是因为浏览器出于安全考虑,我们都知道浏览器有同源策略。如果没有同源策略的情况下,A网站可以被任意来源的Ajax访问到内容,如果当前A网站还处于登录态,那么对方就可以通过Ajax获得A网站的任何消息。当然跨域可以用来房子CSRF攻击,但是并不能完全阻止CSRF。 为什么跨域并不能完全阻止CSRF攻击呢?举个例子: 当请求跨域了,请求是必然发出去的,只是浏览器拦截了响应。你可能会疑问明明通过表单的方式可以发起跨域请求,为什么 Ajax 就不会。因为归根结底,跨域是为了阻止用户读取到另一个域名下的内容,Ajax 可以获取响应,浏览器认为这不安全,所以拦截了响应。但是表单并不会获取新的内容,所以可以发起跨域请求。所以跨域并不能完全阻止 CSRF,因为请求毕竟是发出去了。 上面讲到同源策略,那什么是同源策略呢? 同源策略(SOP)是一种约定,它是浏览器最核心也是最基本的安全功能。浏览器如果缺少同源策略,就会很容易收到xss,csrf等攻击。所谓同源是指“协议+域名+端口”三者相同,即便两个不同的域名指向同一个IP地址,也非同源。 下面来说一下几种方案来解决跨域问题 跨域的方案有: 1、通过jsonp跨域; 2、postMessage跨域; 3、跨域资源共享