前言
以前在面试的时候经常遇到问关于跨域的事儿,所以自己对跨域有一定的概念性了解,知道什么是跨域以及解决跨域的方法,但是具体实际从来没有操作过,直到最近在公司项目中,遇到了一个需要使iframe跨域进行POST提交的实际案例,我才明白具体如何使用iframe进行跨域操作。
说到跨域,就不得不提起浏览器的同源策略。
同源策略限制从一个源加载的文档或脚本如何与来自另一个源的资源进行交互。
源
如果协议,端口(如果指定了一个)和主机对于两个页面是相同的,那么这两个页面就具有相同的源。
从这个定义可以看出,如果两个页面的协议,端口,主机三个只要有一个不一样,就是不同的源,想要相互之间进行交互,就需要进行跨域。
iframe跨域POST无刷新提交
跨域的方法有很多,像JSONP、iframe、CORS、postMessage等等,由于项目中用到了iframe进行POST跨域,所以本文主要总结一下如何利用iframe进行POST无刷新提交。
我们知道一般提交使用form表单进行提交,但是这种提交会导致页面跳转,所以交互效果不是友好,为了实现无刷新提交,我们会使用Ajax,但是此时可能会出现一个问题—-跨域,那么如何解决这个问题呢,可以使用一个隐藏的iframe,我们将要提交的数据提交到这个隐藏的iframe,然后让这个iframe去跳转,这样就可以在视觉上实现页面无跳转刷新(实际上页面还是跳转了,只是iframe被隐藏,我们看不到)。
在提交后我们还要获取到后台给我们返回回来的数据,所以需要在iframe中进行数据的交互同时拿到返回回来的data。
为了让数据可以顺利的进行数据交互,我们通常使用document.domain将域设置到顶级域。
为了拿到返回回来的data,需要使用一个函数,函数名后台已经告知。
附实现代码
<form action="You POST Link" method="post" target="target" id="J_commenting"> <select name="category" class="select J_filter" id="J_typeFilter"> <option value="0" selected="selected">Select Category</option> <option value="1">Life</option> <option value="2">People</option> <option value="3">Landscape</option> <option value="4">Tech</option> <option value="5">Others</option> </select> <input name="title" type="text" class="misstion-title J_misstion-title"> <textarea name="desc" class="misstion-description J_description" maxlength="200"></textarea> <button class="button J_button" type="submit">Submit</button> </form> <iframe name="target" style="display:none;"></iframe>
var $button = $('.J_button'); var $commenting = $('#J_commenting'); var $filter = $('.J_filter'); var $misstionTitle = $('.J_misstion-title'); var $description = $('.J_description'); $button.on('click', function () { var filterValue = $filter.val(); var misstionTitleValue = $misstionTitle.val(); var descriptionValue = $description.val(); if (filterValue === '0' || misstionTitleValue === '' || descriptionValue === '') { alert('Check if you filled out all the fields required'); } else { $commenting.submit(); } }); $commenting.on('submit', function () { document.domain = 'aa.com'; window.addData = function (data) { var dataCode = data.code; var dataMsg = data.message; if (dataCode === 0) { alert('submit success!'); } else { alert('submit failed!'); } } });
点击提交后,后台返回的数据:
document.domain = "aa.com"; var data = {"code":-2,"info":"please login first","message":"please login first"}; if( typeof(parent.window['addData']) == "function"){ parent.window['addData'](data); }else if( typeof(window.top['addData']) == "function"){ window.top['addData'](data); }
总结
以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
本文向大家介绍文件上传,iframe跨域数据提交的实现,包括了文件上传,iframe跨域数据提交的实现的使用技巧和注意事项,需要的朋友参考一下 1、文件上传,图片上传,第三方uploadify插件,http://www.uploadify.com/about/ 2、用iframe上传文件,提交表单,主要思路就是: a、js创建form表单,iframe,添加到body里,form的target要
假设website1.com/page_1.php具有如下表单: 和website2.com/page2.php的iframe如下所示: 使用JQuery或JS,我如何在访问。
本文向大家介绍Jsonp post 跨域方案,包括了Jsonp post 跨域方案的使用技巧和注意事项,需要的朋友参考一下 近期在项目中遇到这样一问题,关于jsonp跨域问题,get传值是可以的,但post传值死活不行啊,于是网上看了一大堆关于这方面的资料,最终问题得以解决,今天抽空与大家分享下。 说明: http://www.t1.com/index.php 服务端URL 当然这是我本地配置的,
本文向大家介绍js关于getImageData跨域问题的解决方法,包括了js关于getImageData跨域问题的解决方法的使用技巧和注意事项,需要的朋友参考一下 在学习h5的时候,canvas标签中getImageData()报错:security error! 具体代码如下(chrome浏览器): 报错信息如下:Uncaught SecurityError: Failed to execute
本文向大家介绍form+iframe解决跨域上传文件的方法,包括了form+iframe解决跨域上传文件的方法的使用技巧和注意事项,需要的朋友参考一下 (1) jsp代码: 说明:form中的target指向iframe中的name。这点要注意。 (2) js代码: (3) 后台java代码: //加<textarea>以解决IE下submit后没有执行回调success函数,这个是jquer
问题内容: 可以说,我有一个名为example.com的网站,在该网站上嵌入了iframe.net域的iframe,现在我想读取iframe的内容并传递一些参数以显示文本消息。像Hi和用户名一样。 现在的问题是,这无法在两者之间建立连接,甚至无法获得我使用以下方法使用的iframe的innerHTML 它将引发错误“权限被拒绝访问属性” 有谁知道如何在跨域平台中读写 问题答案: 如果您无法控制框架