php实现跨域提交form表单的方法【2种方法】


Posted in PHP onOctober 17, 2016

本文实例讲述了php实现跨域提交form表单的方法。分享给大家供大家参考,具体如下:

有时我们为了网站安全考虑,我们不允许直接跨域提交form表单数据,如果我们自己有这个需求呢?下面我们来介绍两种跨域的方法解决直接跨域问题。

下面我们来看看两种php跨域提交form的方法

一、通过php curl

function curlPost($url,$params)
{
   $postData = '';
   foreach($params as $k => $v)
   {
     $postData .= $k . '='.$v.'&';
   }
   rtrim($postData, '&');
   $ch = curl_init();
   curl_setopt($ch,CURLOPT_URL,$url);
   curl_setopt($ch,CURLOPT_RETURNTRANSFER,true);
   curl_setopt($ch,CURLOPT_HEADER, false);
   curl_setopt($ch, CURLOPT_POST, count($postData));
   curl_setopt($ch, CURLOPT_POSTFIELDS, $postData);
   $output=curl_exec($ch);
   curl_close($ch);
   return $output;
}
echo curlPost("http://test.com",array('name'=>"tank"));

以前很多人用curl来抓,邮箱的通讯录,不过现在已经不可以了。哈哈。

二、利用jquery form,ajax提交

1. 下载jquery.form.js

2. js代码

$('#testform').submit(function() {
   $(this).ajaxSubmit({
   type: 'post', // 提交方式 get/post
   dataType:"json",//数据类型
   url: 'your url', // 需要提交的 url
   success: function(data) { // data 保存提交后返回的数据,一般为 json 数据
   // 此处可对 data 作相关处理
   alert('提交成功!');
   }
   $(this).resetForm(); // 提交后重置表单
   });
   return false; // 阻止表单自动提交事件
});

3. php代码

header("Access-Control-Allow-Origin:*"); //跨域权限设置,允许所有
header("Access-Control-Allow-Origin:http://www.test.com"); //只允许test.com跨域提交数据

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
php公用函数列表[正则]
Feb 22 PHP
php实现网站插件机制的方法
Nov 10 PHP
采集邮箱的php代码(抓取网页中的邮箱地址)
Jul 17 PHP
php全局变量和类配合使用深刻理解
Jun 05 PHP
php使用正则表达式提取字符串中尖括号、小括号、中括号、大括号中的字符串
Apr 05 PHP
PHP中array_slice函数用法实例详解
Nov 25 PHP
smarty内置函数foreach用法实例
Jan 22 PHP
PHP使用in_array函数检查数组中是否存在某个值
Mar 25 PHP
完美解决phpexcel导出到xls文件出现乱码的问题
Oct 29 PHP
基于jQueryUI和Corethink实现百度的搜索提示功能
Nov 09 PHP
php中final关键字用法分析
Dec 07 PHP
thinkPHP多表查询及分页功能实现方法示例
Jul 03 PHP
php性能分析之php-fpm慢执行日志slow log用法浅析
Oct 17 #PHP
详解PHP原生DOM对象操作XML的方法
Oct 17 #PHP
php排序算法实例分析
Oct 17 #PHP
基于thinkPHP框架实现留言板的方法
Oct 17 #PHP
php并发加锁示例
Oct 17 #PHP
thinkPHP自动验证、自动添加及表单错误问题分析
Oct 17 #PHP
PHP CURL post数据报错 failed creating formpost data
Oct 16 #PHP
You might like
Yii学习总结之安装配置
2015/02/22 PHP
PHP实现的简单路由和类自动加载功能
2018/03/13 PHP
基于jquery实现的类似百度搜索的输入框自动完成功能
2011/08/23 Javascript
JavaScript修改浏览器tab标题小技巧
2015/01/06 Javascript
原创jQuery弹出层插件分享
2015/04/02 Javascript
jquery实现点击弹出带标题栏的弹出层(从右上角飞入)效果
2015/09/19 Javascript
javascript HTML5 Canvas实现圆盘抽奖功能
2016/04/11 Javascript
js判断复选框是否选中及选中个数的实现代码
2016/05/30 Javascript
js style.display=block显示布局错乱问题的解决方法
2016/09/21 Javascript
Bootstrap3 多选和单选框(checkbox)
2016/12/29 Javascript
微信小程序图片自适应支持多图实例详解
2017/06/21 Javascript
Vue-resource拦截器判断token失效跳转的实例
2017/10/27 Javascript
微信{"errcode":48001,"errmsg":"api unauthorized, hints: [ req_id: 1QoCla0699ns81 ]"}
2018/10/12 Javascript
JS表格的动态操作完整示例
2020/01/13 Javascript
JS script脚本中async和defer区别详解
2020/06/24 Javascript
Python解释执行原理分析
2014/08/22 Python
Python开发常用的一些开源Package分享
2015/02/14 Python
Python Paramiko模块的安装与使用详解
2016/11/18 Python
Python贪心算法实例小结
2018/04/22 Python
使用pandas read_table读取csv文件的方法
2018/07/04 Python
Python 变量类型详解
2018/10/10 Python
numpy数组之存取文件的实现示例
2019/05/24 Python
如何基于Python实现电子邮件的发送
2019/12/16 Python
Pytorch如何切换 cpu和gpu的使用详解
2021/03/01 Python
基于Modernizr 让网站进行优雅降级的分析
2013/04/21 HTML / CSS
Vans(范斯)德国官网:美国南加州的原创极限运动潮牌
2017/05/02 全球购物
欧洲品牌瓷器餐具网上商店:Porzellantreff.de
2018/04/04 全球购物
MAC彩妆英国官网:M·A·C UK
2018/05/30 全球购物
八一建军节感言
2014/02/28 职场文书
庆国庆国旗下讲话稿2014
2014/09/21 职场文书
银行授权委托书范本
2014/10/04 职场文书
民用住房租房协议书
2014/10/29 职场文书
2015年毕业实习工作总结
2015/05/29 职场文书
志愿者工作心得体会
2016/01/15 职场文书
2016年幼儿园教师师德承诺书
2016/03/25 职场文书
干货:如何写好工作计划!
2019/05/17 职场文书