同源策略以及跨域的演示

关于同源策略和跨域的方法看这里

一、演示同源策略

首先找到C盘下的Windows/System32/drivers/etc下的hosts文件,用笔记本打开,添加一条ip和域名

  127.0.0.1   localhost   a.com  b.com
同源策略以及跨域的演示_第1张图片
1.jpg

将a.com和b.com都指向本机。然后打开XAMPP,开启Apache和MySQL,搭建本地服务器。

同源策略以及跨域的演示_第2张图片
2.jpg

在本机的XAMPP下的 htdocs文件夹下写代码 CroosOrigin.html

 
 
    
 
      
      

ajax.js中的代码就一行

   this is ajax.js data.

然后浏览器打开a.com/ CroosOrigin.html。
点击按钮后我们可以看到获得的数据,同源情况下获取数据成功。

同源策略以及跨域的演示_第3张图片
3.jpg

将$.ajax()函数中的url更改成

url:'//b.com/ajax.js', 

刷新a.com/ CroosOrigin.html后点击按钮,弹出获取数据失败,查看控制台:


出错-控制台.jpg

受同源策略限制,a.com和b.com非同源,所以a.com无法请求b.com下的数据。

二、跨域

JOSNP

将a.com/ CroosOrigin.html下的代码改成如下:

   function addScriptTag(src) { 
         var script = document.createElement('script'); 
         script.setAttribute("type","text/javascript"); 
         script.src = src; 
        document.body.appendChild(script);
    }
    $('button').on('click',function(){
        addScriptTag('http://b.com/ajax.js?callback=foo');
    });

    function foo(data) { 
          $('.data').text(data);
    };

将ajax.js中的代码改为如下:

    foo(`this is ajax.js data.`)

即可规避由同源策略带来的限制。点击按钮,数据能正常显示。

你可能感兴趣的:(同源策略以及跨域的演示)