跨域訪問,ajax php
跨域核心代碼(根據自己需求選擇header)
// 允許 baidu.com 發起的跨域請求 header("Access-Control-Allow-Origin: baidu.com"); // 如果需要設置允許所有域名發起的跨域請求,可以使用通配符 * header("Access-Control-Allow-Origin: *");
php代碼
public function callback(){ header("Access-Control-Allow-Origin: *"); echo '你的代碼,推薦使用json數據'; }
完整代碼演示
ajax代碼
<script src="jquery.js"></script> <script type="text/javascript"> $(document).ready(function(){ $.ajax({ url:'http://www.xxx.com/index.php?g=portal&m=gujia&a=callback&mod=86&bid=43&eid=44&area_id=1', success:function(msg){ alert(msg); } }) }); </script>
php代碼
public function callback(){ $mod = I('get.mod','','intval'); $area_id = I('get.area_id','','intval'); $bid = I('get.bid','','intval'); $eid = I('get.eid','','intval'); switch ($mod){ case 86: $result = $this->paiwei($bid,$eid,$area_id); break; default: $result['code'] = '0'; $result['desc'] = urlencode('無效内容'); return urldecode(json_encode($result));exit; } header("Access-Control-Allow-Origin: *"); echo $result; }
總結:
1.跨域問題使用了header,安全性會變低。推薦在局部使用header ,如某個function xxx(){} ,這樣也不會影響整個網站。
2.請注意下通配符 * ,這裡有秘密