美文网首页
js常见跨域解决方案

js常见跨域解决方案

作者: luckyQAQ | 来源:发表于2018-08-07 11:36 被阅读0次

参考:前端常见跨域解决方案(全)

跨域,什么是“域”?

这里就要先说说同源策略了。所谓同源是指"协议+域名+端口"三者相同,即便两个不同的域名指向同一个ip地址,也非同源。

同源策略限制以下几种行为:

1.) Cookie、LocalStorage 和 IndexDB 无法读取

2.) DOM 和 Js对象无法获得

3.) AJAX 请求不能发送

跨域常见解决方案

1.jsonp

原理:ajax请求受同源策略影响,不允许进行跨域请求,而script标签src属性中的链接却可以访问跨域的js脚本,利用这个特性,服务端不再返回JSON格式的数据,而是返回一段调用某个函数的js代码,在src中进行了调用,这样实现了跨域。

jsonp的实现可以查看下面这个链接

菜鸟教程jsonp

缺点:只能发送get请求

2.postMessage跨域

postMessage是HTML5 XMLHttpRequest Level 2中的API,且是为数不多可以跨域操作的window属性之一,它可用于解决以下方面的问题:

a.) 页面和其打开的新窗口的数据传递

b.) 多窗口之间消息传递

c.) 页面与嵌套的iframe消息传递

d.) 上面三个场景的跨域数据传递

html5 postMessage解决跨域、跨窗口消息传递

3.跨域资源共享(CORS)

a.) 普通跨域请求:只服务端设置Access-Control-Allow-Origin即可,前端无须设置。

b.) 带cookie请求:前后端都需要设置字段,另外需注意:所带cookie为跨域请求接口所在域的cookie,而非当前页。

c.) 目前,所有浏览器都支持该功能(IE8+:IE8/9需要使用XDomainRequest对象来支持CORS)),CORS也已经成为主流的跨域解决方案。

CORS简介

4.其他跨域方式

1、 document.domain + iframe跨域

2、 location.hash + iframe

3、使用websocket(Websocket原理及使用场景[转载]

4、使用nginx反向代理(nginx反向代理-解决前端跨域问题

相关文章

  • 跨域解决方案

    收集整理了常见跨域解决方案,欢迎补充指正。 通过jsonp跨域 通常为了减轻web服务器的负载,我们把js、css...

  • 跨域

    博客 说说跨域那些事儿 不要再问我跨域的问题了 前端常见跨域解决方案(全) 同源策略 JSONP(填充式JSON)...

  • 常见跨域解决方案

    目前常见的跨域解决方案 Jsonp最早的解决方案,利用script标签可以跨域的原理实现限制: 需要服务的支持 只...

  • js常见跨域解决方案

    参考:前端常见跨域解决方案(全) 跨域,什么是“域”? 这里就要先说说同源策略了。所谓同源是指"协议+域名+端口"...

  • 前端常见跨域解决方案(全)

    前端常见跨域解决方案(全) 什么是跨域? 跨域是指一个域下的文档或脚本试图去请求另一个域下的资源,这里跨域是广义的...

  • Webpack 配置 proxy 代理解决跨域问题

    问题 JS跨域及解决方案[https://www.jianshu.com/p/0e9a368ffb74]介绍了跨域...

  • 前端不同的跨域方案总结

    做个收录,方便以后复盘。本文转自:前端常见跨域解决方案(全)。 什么是跨域? 跨域是指一个域下的文档或脚本试图去请...

  • javascript -- Worker加载跨域

    worker 加载js脚本跨域解决方案 错误代码如下Uncaught (in promise) DOMExcept...

  • JWT简介

    前言 JSON Web Token(JWT)是目前最流行的跨域身份验证解决方案。微服务常见的认证方案 一、跨域认证...

  • JW-JSONP

    去年学习React时碰到过JS跨域访问的问题,当时尝试的解决方案有Jsonp、服务器允许跨域、设置Content-...

网友评论

      本文标题:js常见跨域解决方案

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