ajax跨域(基础域名相同)表单提交的方法

1.要在做ajax提交的页面中添加如下js语句:

<script type="text/javascript"> document.domain="基础域名"; </script>

2.ajax表单提交表单时可以使用一个jquery的一个表单插件jquery.form.js

使用语法如下:

//fromPost为要收集数据的form表单的id $("#formPost").ajaxSubmit({ url:"跨域的业务处理地址", cache:false, dataType:"html", iframe:true, success:function (data){ //返回如果是json可以这样处理一下,xml格式需要做其它的处理 eval("data="+data); if(data.flag == 'OK'){ } });

3.跨域的业务处理的返回值中必需含有以下语句

<script type="text/javascript"> document.domain="基础域名"; </script>

4.剩下的返回值可以是json,xml格式或其它自定义的格式,只要客户端能够解析出想要结果就可以

5.这样在做ajax提交的页面中就可以取到表单跨域提交后的返回值了,取到返回值后就可以接着做其它的处理了

说明:

1.基础域名:两个及两个以上域名的公有部分,公有部分至少要包含二级域名或二级域名之上的部分

2.document.domain="基础域名"; //这句话是为了使域名相同,解除跨域的限制,详见:《js设置document.domain实现跨域的注意点分析

3.关于跨域提交还有很多其它的解决办法,如:《js同源策略详解

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wfyxgw.html