根据千峰教育学习视频所练习的笔记 | 学习一段时间,我也有写一点东西的必要了···html
源是指协议、域名和端口号。 同源策略:是浏览器的一种安全机制。
也就是说,当脚本运行时,浏览器会检测它所执行的脚本以及它取得的数据与咱们的HTML页面所在的源是否相同。就是说咱们请求数据的协议、端口号以及域名与咱们HTML的协议、域名、端口号是否一致。一致就认为ok,是同源的,它就会进行成功的请求。若它们的源不一致,这个时候就是跨域的请求。
默认状况下,浏览器是不支持跨域请求的前端
咱们知道,Ajax的执行会受到同源策略限制,由于脚本运行时发送数据,它(浏览器)会检测请求数据的域名、协议和端口号。那么,script标签时不受同源策略限制(在请求script脚本的时候,不管脚本是HTML所在服务器仍是在其余服务器,它都能请求),咱们就能用script的这一性质来进行数据请求。ajax
举个栗子:json
1)如今个人脚本中定义一个getData的函数,而且定义了形参data,将数据简单输出。后端
<script> function getData(data){ consle.log(data); } </script>
2)若是如今我请求了一个脚本,脚本能调用个人getData,而且把数据做为实参传递进来。那个人形参接收到数据就能够进行相应的处理了。接下来模拟一下这个过程。跨域
假定我有一个jsonp.js,如今前端把函数名告诉了后端,后端在jsonp.js文件里就能调用data,而且在这儿传递一个数据。浏览器
getData({ name:'feifei', age:'9' })
3)回到刚刚的script里,咱们能请求jsonp.js文件。安全
<script> function getData(data){ console.log(data); } var script = document.createElement('script');//动态建立script标签 script.id = "jsonp"; script.src = "./jsonp.js";//将script标签的src指向当前路径下的jsonp document.body.appendChild(script); </script>
这种方式咱们就获得想要的数据了,而且它不受同源策略的限制。服务器
CORS全称是跨域资源共享,是通常浏览器都支持的功能。整个CORS通讯过程都有浏览器自动完成,不须要用户参与。对于前端开发者来讲,发送CORS的Ajax和发送普通的Ajax没有什么区别。实现CORS通讯的关键在服务器端,只要服务器实现了CORS接口就能够跨域通讯。app