本文实例讲述了php实现跨域提交form表单的方法。分享给大家供大家参考,具体如下:
有时我们为了网站安全考虑,我们不允许直接跨域提交form表单数据,如果我们自己有这个需求呢?下面我们来介绍两种跨域的方法解决直接跨域问题。
下面我们来看看两种php跨域提交form的方法
一、通过php curl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
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代码
1
2
3
4
5
6
7
8
9
10
11
12
13
|
$( '#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代码
1
2
|
header( "Access-Control-Allow-Origin:*" ); //跨域权限设置,允许所有
header( "Access-Control-Allow-Origin:http://www.test.com" ); //只允许test.com跨域提交数据
|
希望本文所述对大家PHP程序设计有所帮助。