前端跨域问题

1.跨域问题的由来

首先我们需要了解的是,前端处于项目开发过程中最接近用户的一个区域,代码最容易被hack获取解析,也最容易受到攻击。针对这个问题,互联网早期探索者Netscape提出了一个著名的安全策略——同源策略:浏览器限制脚本中发起的跨站请求,要求Java或cookie只能访问同源的资源。这里的同源指的是,域名,协议名,以及端口号相同。正是由于这个机制,才致使我们无法用简单的手段来请求不同域名下的资源。

云备份2019新版下载!
广告
云备份2019新版下载!

2.如何解决跨域问题

2.1跨域资源共享CORS

展开剩余92%
                    </div>
                        
                        <div class="hidden-content hide">
                            <p class="ql-align-justify">CORS是W3C提出的一个标准——CORS跨域资源共享(Cross-Origin Resource Sharing)。它允许浏览器向跨域服务器发出请求,从而克服AJAX只能同源使用的限制。</p>

首先CORS需要浏览器和服务器同时支持,现代浏览器包括IE10+都支持CORS请求。

使用CORS跨域的时候和普通的AJAX过程是一样的。浏览器一但发现AJAX请求跨域资源,就会自动添加一些请求头帮助我们处理一些事情。所以说只要服务端提供CORS支持,前端不需要做额外的事情。

CORS请求分两种,这里简单介绍其中一种:

i)简单请求(simple request)

满足以下两大条件,就属于简单请求。

1、请求方式是head,get,post三者中其一

2、http请求头信息不超出以下字段:Accept、Accept-Language、Last-Event-ID、Content-Type:只限于application/x-www-form-urlencoded、multipart/form-data和text/plain

浏览器在进行简单请求时,伴随着ajax请求的产生,浏览器会自动添加origin字段,表明请求来源。服务器会识别出源,并且决定是否返回数据给该源。

如果origin并不在服务器许可范围内,服务器会返回一个正常的http。浏览器接受后发现这个http的头信息中不包含Access-Control-Allow-Origin字段,就知道出错了,随后在浏览器会抛出相应的error。

这里列出几个返回http中常见的几个CORS请求头:

1.Access-Control-Allow-Origin:该字段为必需字段,可以是指定的源名(协议+域名+端口),也可以使用通配符*代表接受所有跨域资源请求

2.Access-Control-Allow-Credentials:该字段为boolean值,表示是否允许发送cookie,默认为false,即不允许发送cookie值。

3.Access-Control-Expose-Headers:该字段可选。CORS请求时,对象的getResponseHeader()方法只能拿到6个基本字段:Cache-Control, Content-Language, Content-Type, Expires, Last-Modified, Pragma.如果想拿到其他的字段,必须在Access-Control-Expose-Headers里面指定。

ii)非简单请求

非简单请求会对服务器有特殊的要求,在正式通信之前,会增加一次http查询请求,会额外的占用资源,并进而影响到请求速度。达观数据在数据处理以及返回数据的过程中对性能有着极高的要求,在实际项目中并没有尝试这种实现方式。笔者本人也并未对此做过深入学习,在此就不班门弄斧了。

2.2使用jsonp进行跨域请求

Jsonp可以说是目前跨域问题的最普遍的解决方案了。在此简要介绍一下jsonp的概念。首先,jsonp跟json只有一字母之差,但完全是两个概念,json是一种数据存储的基本格式,通常见于js脚本存储数据,ajax请求数据。而jsonp是一种非正式的传输协议,该协议的一个要点是允许用户传递一个callback参数给服务端,服务端返回数据时,会将callback参数作为函数名来包裹住JSON数据,这样客户端就可以随意定制自己的函数来自动处理返回数据了。

Jsonp的原理是:普通资源请求都会受到跨域影响,但含有src属性的跨域资源在调用时并不会受到影响。Jsonp就是由于这种特性被发掘并实现跨域的。

在使用jsonp进行跨域请求时,首先我们需要注册一个callback回调函数,这个函数需要接受一个参数。然后我们需要动态生成一个标签,并在请求的src中加入我们的callback名称。

例如:callback名为alertMessage,然后我们在页面中动态添加src为www.datagrand.com? callback=alertMessage的标签。这样,一条请求就向服务端发送成功了。服务端在接收并识别出callback后,将想要返回的数据动态的包裹在callback括号内。

加载成功后,会执行本地alertMessage方法,将最终的结果alert出来。本质上,jsonp就是将需要执行的函数的名传递给服务端,并在服务端将对应的数据包装到函数参数域内,并返回到本地进行调用的过程。

2.3小众跨域方式

除了CORS和jsonp之外还有一些比较小众的跨域方式,在此就将这些放在一起整理出来。

i)document.domain

首先我们需要知道的是,页面中的iframe和其父页面的window对象是可以互相获取到的(尽管取到的window对象不能拿到方法和属性)。但是我们可以通过修改document.domain这一属性,来使获得window对象具有方法和属性。这里需要注意的是,iframe和其父页面的主域名必须相同。例如,在www.datagrand.com/index.html页面中嵌入一个src为shilieyu.datagrand.com/index.html的iframe,同时修改两个页面的document.domain为datagrand.com。这样就可以在互相获取到对方页面的window对象中,就会存在方法和属性了。这时,在其中一个页面中可以使用ajax请求数据,另一个页面就可以使用window对象获取到对应数据。

ii)window.postMessage

postMessage为html5中引进的方法,该方法可以向其他window对象发送消息,无论这个window对象是否同源。

首先是postMessage方法的参数,postMessage接受两个参数,第一个为要发送的消息,该参数只能为字符串类型,第二个参数用来限定接受消息的window对象所在域。如果不想限定,可以使用通配符*允许所有域接受该消息。需要接收消息的window对象,需要监听自身的message事件,来获取传过来的消息。事件触发时,可以通过接受参数的data值,来获取对应的数据。举例,如下图所示,在a页面中创建指向b页面的iframe并在其阶段调用postMessage方法,随后在iframe完成时,页面会alert出a页面传递过去的值。也就意味着跨域成功。

使用postMessage的a页面

接受postMessage的b页

Window的name属性有个很有趣的特点,在一个窗口(window)的生存周期内,所有的页面的都是共享一个name属性,每个页面对window.name都有这读写的权限,这也就意味着,在页面即将发生跳转时,我们可以将想要传递的数据放入window.name中,在页面跳转成功后,新页面可以用通过window.name获取前页面传递过来的值。

利用这种特性,我们可以在a页面通过iframe的形式,先访问存储数据的页面,将请求值存入iframe的window.name中,再讲src设置为与a页面同源的页面,否则是无法通过window获取到iframe中的属性的(详见window.domain中内容)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
牙科就诊管理系统利用当下成熟完善的SSM框架,使用跨平台的可开发大型商业网站的Java语言,以及最受欢迎的RDBMS应用软件之一的Mysql数据库进行程序开发。实现了用户在线查看数据。管理员管理病例管理、字典管理、公告管理、药单管理、药品管理、药品收藏管理、药品评价管理、药品订单管理、牙医管理、牙医收藏管理、牙医评价管理、牙医挂号管理、用户管理、管理员管理等功能。牙科就诊管理系统的开发根据操作人员需要设计的界面简洁美观,在功能模块布局上跟同类型网站保持一致,程序在实现基本要求功能时,也为数据信息面临的安全问题提供了一些实用的解决方案。可以说该程序在帮助管理者高效率地处理工作事务的同时,也实现了数据信息的整体化,规范化与自动化。 管理员在后台主要管理病例管理、字典管理、公告管理、药单管理、药品管理、药品收藏管理、药品评价管理、药品订单管理、牙医管理、牙医收藏管理、牙医评价管理、牙医挂号管理、用户管理、管理员管理等。 牙医列表页面,此页面提供给管理员的功能有:查看牙医、新增牙医、修改牙医、删除牙医等。公告信息管理页面提供的功能操作有:新增公告,修改公告,删除公告操作。公告类型管理页面显示所有公告类型,在此页面既可以让管理员添加新的公告信息类型,也能对已有的公告类型信息执行编辑更新,失效的公告类型信息也能让管理员快速删除。药品管理页面,此页面提供给管理员的功能有:新增药品,修改药品,删除药品。药品类型管理页面,此页面提供给管理员的功能有:新增药品类型,修改药品类型,删除药品类型
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值