您好,欢迎访问一九零五行业门户网

PHP+AJAX实现跨域的方式

php文件代码【我是以phpcms来做实例】
在phpcms\modules文件夹下添加了一个mobile的文件夹【模块】;在该模块下添加一个index.php文件,代码如下:
/**
public function test()
   {
       //加载数据库模型
       $mb_start_db = pc_base::load_model('mb_start_model');
       $where = array('id'=>1);
       $data = ('pic1,pic2,pic3');
       $res = $mb_start_db->get_one($where, $data);
if($res)
       {
           if(!empty($_get['callback'])) {
               $json_arr = array('status'=>1,'msg'=>'成功!','result'=>$res);
               echo $_get['callback']. '('.json_encode($json_arr).')';die;
           } else {
               $json_arr = array('status'=>1,'msg'=>'成功!','result'=>$res);
               echo json_encode($json_arr);die;
           }
       }
}
这是一份完整的代码
**/
注::上面的代码有一个$_get['callback'],这个就是jsonp一个参数;
再看看html5页面的代码:
最终效果图如下::
但你点击了获取数据这个按钮【注:按钮的名称应该是获取数据的,不好意思打错字】,会出现以下的错误:
这个错误是不允许,或者说禁止跨域,要解决这个方法很简单,在php文件的头部加上一段代码:
/**
header(access-control-allow-origin:*);
*号表示所有域名都可以访问  
**/
加了以上代码,最终的效果如下图:
如果datatype:'jsonp'的话,如下图片
看php代码:
结果如下:
简单总结2点:
1、ajax请求的时候使用jsonp,然后在php接收和返回的时候也带上jsonp的数据;
2、只提供给支持html5的浏览器使用,只需要在php的头部加上如下这两句话即可
header(access-control-allow-origin:*); //*号表示所有域名都可以访问  
header(access-control-allow-method:post,get);
更多php+ajax实现跨域的方式。
其它类似信息

推荐信息