技术头条 - 一个快速在微博传播文章的方式     搜索本站
您现在的位置首页 --> PHP --> php 跨域 form提交 2种方法

php 跨域 form提交 2种方法

浏览:1718次  出处信息

   出于安全因素考虑,直接跨域访问是不允许的,下面介绍二种跨域的方法。

   一,通过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跨域提交数据

建议继续学习:

  1. 优雅绝妙的Javascript跨域问题解决方案    (阅读:6758)
  2. jQuery中getJSON跨域原理详解    (阅读:5638)
  3. 跨域请求的iframe解决方案(1)    (阅读:5409)
  4. ajax-cross-domain    (阅读:5004)
  5. 利用跨域资源共享(CORS)实现ajax跨域调用    (阅读:4168)
  6. 研究ext发现ajax跨域实现    (阅读:3754)
  7. 三谈Iframe自适应高度    (阅读:3651)
  8. 使用window.postMessage实现跨域通信    (阅读:3414)
  9. 使用document.domain和iframe实现站内AJAX跨域    (阅读:3330)
  10. 跨域请求的iframe解决方案(2)    (阅读:3164)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
© 2009 - 2024 by blogread.cn 微博:@IT技术博客大学习

京ICP备15002552号-1