關於ajax跨域訪問,Access-Control-Allow-Origin 404的簡單解決辦法
~關於ajax跨域,都是一個老生常談的問題了,解決方法很多,比較常用的是JSONP方法,JSONP方法是一種非官方方法,而且這種方法只支援GET方式,不如POST方式安全(大家應該都知道)。即使使用jquery的jsonp方法,type設為POST,也會自動變為GET。(實踐才是硬道理)
例如:客戶端的域名是www.c.com,而請求的域名是www.s.com
如果直接使用ajax訪問,會有以下錯誤
XMLHttpRequest cannot load http://www.server.com/server.php. No 'Access-Control-Allow-Origin' header is present on the requested resource.Origin 'http://www.c.com' is therefore not allowed access
如果後臺用的PHP:
在被請求的Response header中加入
// 指定允許其他域名訪問header('Access-Control-Allow-Origin:*');
// 響應型別header('Access-Control-Allow-Methods:POST');
// 響應頭設定
header('Access-Control-Allow-Headers:x-requested-with,content-type');
如果後臺用的Java:
新增如下設定允許跨域即可
response.setHeader("Access-Control-Allow-Origin", "*");
新增位置可以在下面三處任選一個。
1.可以在過濾器 filter 中的 dofilter() 方法設定。
2.可以在 servlet 的 get 或者 post 方法裡面設定。
3.可以放在訪問的 jsp 頁面第一行。
這樣就能輕鬆解決了!是不是美滋滋呀!