菜单

利用 Flash 完美解决 JavaScript 和 AJAX 跨域 HTTP POST/GET 表单请求

2015-01-03 - 优秀原创

[ 作者:张宴]

最近的一个项目中,需要通过 JavaScript 提交表单数据到另一个域名下的PHP接口(因为数据较大,需要HTTP POST方式提交),并获取PHP接口的返回值,在页面无刷新、无跳转的情况下,更新div标签内的内容。

浏览器出于安全考虑,是不允许JavaScript代码进行跨域操作。JavaScript 和 AJAX 跨域访问分为两大类,一是本域和子域的交互,二是本域和其他域的交互。

一、本域和子域的交互:www.zyan.cc 和 blog.zyan.cc
二、本域和其他域的交互:blog.zyan.cc 和 api.bz

本域和子域的交互,可以通过iframe设置两个域名document.domain = “zyan.cc”,实现统一zyan.cc域下的跨域访问。

本域和其他域的交互,可以通过iframe、代理、JS创建动态脚本等几种方法来实现,这里有篇文章对几种方法作了简要的介绍

iframe、JS创建动态脚本这两种方法,需要开发者能控制两个域,两端都要编写相应的代码,非常麻烦。在本域服务器上用PHP写个代理中转程序,让 本域PHP程序去读取远程其他域的数据再返回给自己,是常用的方法。但是,在本域“前端是CDN或Squid缓存服务器,后端才是PHP应用程序服务器” 的系统架构下,穿透CDN或Squid去访问不能被缓存的PHP代理中转程序,效率是很低的。


国外有人尝试用 Flash 做 JavaScript 和 AJAX 跨域访问中转,无疑是一个好方法。JavaScript 将数据提交给本域下的 Flash,通过 Flash 中转去访问其他域的接口,条件只需要其他域的根目录下有一个crossdomain.xml文件,文件中设置允许所有域名或允许本域访问即可。很多网站的 API域名都提供了crossdomain.xml文件。

转载请注明: 转载自—艾瑞可erik

本文链接地址: http://erik.xyz/611.html

页面: 1 2 3 4 5 6 7

标签:, , ,

发表评论