美文网首页
同源策略以及跨域的演示

同源策略以及跨域的演示

作者: 黄露hl | 来源:发表于2017-01-06 20:59 被阅读0次

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

一、演示同源策略

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

  127.0.0.1   localhost   a.com  b.com
1.jpg

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

2.jpg

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

 <!DOCTYPE html>
 <html>
 <head> <meta charset="utf-8"><title></title>  </head>
 <body>
      <button>点我获取数据</button>
      <div class="data"></div>
      <script src='http://apps.bdimg.com/libs/jquery/2.1.4/jquery.js'></script>
      <script type="text/javascript">
       $('button').on('click',function(){
         $.ajax({
        url:'//a.com/ajax.js', //或直接写ajax.js
        dataType:'text',
        type:'get',
        success:function(data){
            $('.data').text(data);
        },
        error:function(){
            alert('获取失败');
        }
    });
})
</script>
</body></html>

ajax.js中的代码就一行

   this is ajax.js data.

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

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.`)

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

相关文章

  • 同源策略以及跨域的演示

    关于同源策略和跨域的方法看这里 一、演示同源策略 首先找到C盘下的Windows/System32/drivers...

  • 跨域的几种方式

    跨域以及跨域的几种方式 讲解跨域之前我们先来看看什么是同源策略 什么是同源策略 通常来说,浏览器出于安全方面的考虑...

  • H5跨域访问

    跨域访问是源于浏览器的同源策略而引申出来的概念 1、先了解什么是同源策略和跨域访问 同源策略、跨域解决方案 - R...

  • H5 知识点 - 收藏集 - 掘金

    跨域解决方案总结 - 前端 - 掘金为什么需要跨域? 就得先知道同源策略. 同源策略 同源策略是为了保证数据的安全...

  • 通过script标签实现跨域

    跨域 什么是跨域? 跨域问题是由于javascript语言安全限制中的同源策略造成的。同源策略是由Netscape...

  • 同源策略,跨域请求处理

    跨域访问 - 跨域请求 同源策略 适用于浏览器的一种资源访问策略;同源策略(Same origin policy)...

  • 无星的Egg之旅(一)——跨域

    先说点老生常谈的问题 啥是跨域 1.同源策略 要了解跨域,先要说说同源策略。同源策略是由 Netscape 公司提...

  • 前端基础(问答23)

    keywords: 同源策略、跨域、jsonp。 什么是同源策略(same origin policy) 同源:协...

  • 有关跨域的相关问题和方法

    跨域是什么 同源策略 在讲解什么是跨域之前先要清楚什么是同源策略,“同源政策”(same-origin polic...

  • 同源策略和跨域

    什么是跨域问题? 为什么会出现跨域问题? 因为浏览器的同源策略(同源指的是:协议+域名+端口相同)。 同源策略是浏...

网友评论

      本文标题:同源策略以及跨域的演示

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