【AJAX】跨域问题笔记

同源策略是浏览器的安全机制,限制了不同源之间的交互。跨域可以通过JSONP和CORS解决。JSONP利用script标签的跨域特性,适用于GET请求;CORS是服务器设置响应头允许特定源的跨域请求,支持更多请求类型。
摘要由CSDN通过智能技术生成

跨域

一、同源策略(Same-Origin Policy)

是浏览器的安全机制。

同源:协议、域名、端口号必须完全相同

客户端

 服务端

违背同源策略就是跨域

  二、如何解决跨域

1、JSOPN

 (1)JSONP是什么

JSONP(JSON with Padding),是一个非官方的跨域解决方案,纯粹凭借程序员开发出来,只支持get请求。

 (2)JSONP怎么工作

在网页里有些标签天生具有跨域能力,比如:img \ link \ iframe \ script。

JSONP就是利用script标签的跨域能力来发送请求的。

(3)JSONP的使用

a、动态的创建一个scrip标签

var script =  document.createElement['scrip'];

b、设置script的src.设置回调函数

script.src ="http://localhost:3000/testAJAX?callback=abc";

2、CORS(Cross-Origin Resource Sharing)

(1)跨域资源共享,特点是不需要在客户端做任何特殊操作,完全在服务器中进行处理,支持get和post请求。跨域资源共享标准新增一组HTTP首部字段,允许服务器声明哪些源站通过浏览器有权限访问哪些资源。

(2)CORS是通过设置一个响应头来告诉浏览器,请允许跨域,浏览器收到该响应以后会对响应放行。

(3)主要的是服务器端的设置:

router.get("/xx",function(req,res){})

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值