关于JS跨域

我所理解的JS跨域指的是:浏览器出于安全方面的考虑,只允许与本域下的接口交互。不同源的客户端脚本在没有明确授权的情况下,不能读写对方的资源。也就是说可以理解成违反了同源策略的三种情况,我们就可以理解成跨域。

JS同源策略指的是以下三个:

  1. 域名相同,如:jrg.com和jirengu.com的域名不同,那么这两个就不是同源的
  2. 端口相同,如:jrg.com:8080和jrg.com:8088就是不同端口的
  3. 协议相同,如都是http协议或都是https协议或都是file协议

既然存在跨域这种情况,那么肯定存在解决方法,一般能用到的几种解决跨域的方法:

  1. JSONP
  2. CORS(添加响应头的方式)
  3. 针对iframe的情况可以使用降域。
  4. postMessage

下面简单说一下这几种不同的方法:

JSONP

JSONP是利用script标签的特性来解决跨域问题的,script标签可以引入其他域的内容,不会被浏览器阻止,所以我们可以利用这个特性,给script标签的src属性赋值成其他域提供的接口(一般格式大概是src="http://www.a.bbs.com/?news=beijing?callback=show"),然后利用一个函数(就例子来说这个函数就是callback后面的show)来处理我们拿到的其他域的数据,使其展示在页面上。这种办法和AJAX完全没有关系,同样的,也不会受到跨域的影响。举个例子:

//页面代码
btn.addEventListener("click",function (){
    var script = document.createElement("script");
    script.src = "http://localhost:8080/getNews?callback=show"
    document.head.appendChild(script);
    //document.head.removeChild(script);
})

function show(news){                //news是个参数,这个参数是个引用类型,可能是数组,也可能是JSON
    var content = '';
    for(var i = 0; i<news.length; i++){
        content+='<li>' + news[i] + '</li>';
    }
    ct.innerHTML = content;
}

//服务端代码
app.get("/getNews",function(req,res){
  var news = [
    "总结了日式网站这4个优点后,我能把中文网站做得高大上了!",
    "写给沉迷于学习新软件的设计师:技多真的不压身吗?",
    "IOS 10 VS 11:一份全面深入的UI对比分析报告",
    "在配色这件事情上,总会有一些有趣且有用的小技巧",
    "那些让人一见钟情的网页首屏,遵循着怎样的设计模式?",
    "漫山遍野的多边形元素,正在入侵每一份设计稿",
    "配色高手系列!聊聊“黑色”在电商设计里的常用搭配技巧!",
    "设计反复修改?可能是你的信息层级没有梳理好!"
    "如何制造信赖感和惊喜感?我总结了这些设计方法"
  ];
  var data = [];
  for(var i = 0; i<3; i++){
    var index = parseInt(Math.random()*news.length);    //获取随机数来实现随机获取新闻中的某一条
    data.push(news[index]);     //建立新数组用来保存新闻
    news.splice(index,1);     //去重复
  }
  
  var callback = req.query.callback;    //如果请求参数含有callback
  if(callback){
    res.send(callback+'(' + JSON.stringify(data) + ')');    //show("xxxx","xxxx")
  }else{
    res.send(data);
  }
})

CORS

CORS 全称是跨域资源共享(Cross-Origin Resource Sharing),是一种 ajax 跨域请求资源的方式,支持现代浏览器,IE支持10以上。它的原理是针对响应头加入一段代码使浏览器能辨识我们的跨域请求并执行,这里就得啰嗦一下浏览器的一个特性,我们向不同域的接口去请求数据的时候,我们请求的服务器是一定会给你相应的数据的,但是当数据来到之后,浏览器会辨识你的数据是否是跨域的请求,如果是跨域的请求,浏览器会阻止你的行为,所以说,跨域其实是浏览器的一种特性。

实现方式:当使用 XMLHttpRequest 发送请求时,浏览器发现该请求不符合同源策略,会给该请求加一个请求头:Origin,后台进行一系列处理,如果确定接受请求则在返回结果中加入一个响应头:Access-Control-Allow-Origin; 浏览器判断该响应头中是否包含 Origin 的值,如果有则浏览器会处理响应,我们就可以拿到响应数据,如果不包含浏览器直接驳回,这时我们无法拿到响应数据。不多说了,先上代码吧~

//页面JS
var btn =document.querySelector("button");
    var ct =document.querySelector('#ct');
    var pageIndex = 0;

    btn.addEventListener("click",function(){
        var xhr = new XMLHttpRequest();
        xhr.open("get","http://a.jrg.com:8080/getNews",true);
        xhr.send();
        xhr.onreadystatechange = function(){
            if(xhr.readyState === 4 && xhr.status ===200 || xhr.status === 304){
                show(JSON.parse(xhr.responseText));
            }
        }
    })
    function show(news){
        var content = "";
        for(var i = 0; i<news.length; i++){
            content += '<li>' + news[i] + '</li>';
        }
        ct.innerHTML = content;
}


//服务端代码
app.get("/getNews",function(req,res){
  var news = [
    "用1年时间让DRIBBBLE 涨粉过万,我是怎么做到的?",
    "没灵感?这里是最全的12个LOGO设计风格总结!",
    "IOS 10 VS 11:一份全面深入的UI对比分析报告",
    "在配色这件事情上,总会有一些有趣且有用的小技巧",
    "那些让人一见钟情的网页首屏,遵循着怎样的设计模式?",
    "漫山遍野的多边形元素,正在入侵每一份设计稿",
    "配色高手系列!聊聊“黑色”在电商设计里的常用搭配技巧!",
    "设计反复修改?可能是你的信息层级没有梳理好!",
    "如何做落地页设计?这儿有20个顶尖的案例和优点分析",
    "不懂服务设计?看看它的演变历史你就知道了!",
    "深度好文!如何积极正确地使用「预设计」方法?",
    "省时高效!苹果官方的设计流程和实用工具推荐"
  ];
  var data = [];
  for(var i = 0; i<7; i++){
    var index = parseInt(Math.random()*news.length);    //获取随机数来实现随机获取新闻中的某一条
    data.push(news[index]);     //建立新数组用来保存新闻
    news.splice(index,1);     //去重复
  }
  //res.header("Access-Control-Allow-Origin","*")       //CORS的核心思想
  res.header("Access-Control-Allow-Origin","http://a.jrg.com:8080")       //CORS的核心思想
  res.send(data);
})

降域

降域一般是针对页面内嵌得iframe来进行处理的方法,降域的核心思想是将一个一级域名下的几个子域名来降域到同一个域名以实现处理iframe和引入它的页面之间的跨域问题,主要的核心代码是:document.domain = ""。降域的一般方法如下:

降域1.png
降域2.png

postMessage

postMessage也是一种处理iframe跨域的方法,比使用document.domain会更加方便一些,我们可以理解成主页面向iframe发送一些信息,如果iframe需要就可以监听这些消息,如果不需要就可以不监听这些消息,同样的iframe也可以像父页面发送消息,主页面也是可以监听到这些消息的,如果不需要,就不监听这些消息。
代码如下:


postMessage1.png
postMessage2.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容

  • 1. 什么是跨域 跨域,是指浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的,是浏览器对JavaScri...
    cbw100阅读 6,328评论 2 86
  • 一叶忽然落,惊醒忆中人。 漫步秋丛里,惆怅复失神。 此地是熟地,今人非故人。 浅笑不觉无,改观换深沉。
    一夫爱青剑兮呜呼不孤阅读 129评论 0 4
  • 毕业季大家忙着找工作,我针对面试的一些基本回答逻辑和考察重点,分享一些微小的人生经验。 本人水平有限,疏漏之处在所...
    终端悍匪阿星阅读 1,947评论 0 5
  • 为什么你总是不相信别人的努力? "唉,知道么?小C换了辆车,四个圈!" "那又怎样?人家含着金钥匙出生,换啥车也不...
    清风明月7773阅读 464评论 1 2
  • 近两个月来温哥华也有三四次了,就来这个国家次数也想提笔写写温哥华,但每次想写点什么,却总是苦于无从下笔。每个国家每...
    丁芳芳阅读 478评论 1 1