本文实例讲述了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程序设计有所帮助。