這篇文章主要介紹了php實現跨域提交form表單的方法,結合實例形式分析了curl及ajax兩種方法進行跨域提交的操作技巧,需要的朋友可以參考下
本文實例講述了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實作跨域提交form表單的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!