1. 程式人生 > >關於ajax跨域訪問,Access-Control-Allow-Origin 404的簡單解決辦法

關於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 頁面第一行。

這樣就能輕鬆解決了!是不是美滋滋呀!