有關(guān)Ajax跨域問(wèn)題的兩種解決方法
概述
Ajax跨域是前端開(kāi)發(fā)中常見(jiàn)的問(wèn)題,本文描述了以Google瀏覽器Chrome作為客戶端和以Tomcat作為Web服務(wù)器的情況下的解決辦法。
問(wèn)題現(xiàn)象
當(dāng)出現(xiàn)跨域訪問(wèn)的時(shí)候ajax通常會(huì)報(bào)類似如下錯(cuò)誤:
XMLHttpRequest cannot load http://192.168.2.12:8001/oss/api/version/check. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:8000' is therefore not allowed access.
解決辦法一:關(guān)閉瀏覽器的跨域安全設(shè)置,僅限于開(kāi)發(fā)的時(shí)候測(cè)試用
以chrome瀏覽器為例,右鍵點(diǎn)擊chrome的快捷方式,然后在Target的值后面追加 --disable-web-security,注意--前面有個(gè)空格。例如:
"C:\Program Files (x86)\Google\Chrome\Application\chrome.exe" --disable-web-security
啟動(dòng)之后,Chrome瀏覽器會(huì)提示您"您使用的是不受支持的命令行標(biāo)記:--disable-web-security",說(shuō)不安全,因此僅限于測(cè)試。
這樣就可以直接測(cè)試,不會(huì)出現(xiàn)跨域的錯(cuò)誤了!
解決辦法二:配置Web服務(wù)器支持跨域訪問(wèn)
這里描述以Tomcat為Web服務(wù)器情況下的解決辦法,在Java Web程序的WEB-INF下的web.xml文件中加入如下配置即可。
<!--cors filter-->
<filter>
<filter-name>CorsFilter</filter-name>
<filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>CorsFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
注意:org.apache.catalina.filters.CorsFilter下面有好幾個(gè)配置的選項(xiàng),上面沒(méi)有配置時(shí)就采用系統(tǒng)的默認(rèn)配置。在實(shí)際生產(chǎn)環(huán)境要根據(jù)需要進(jìn)行配置來(lái)提高安全性。比如cors.allowed.origins配置允許訪問(wèn)的源地址,默認(rèn)為所有,即*。此外,還有cors.allowed.methods,cors.allowed.headers等等。具體的配置細(xì)節(jié)請(qǐng)參見(jiàn)本文參考資料中的[1]。
以上兩種方法均能解決ajax跨域問(wèn)題,希望本文分享對(duì)大家有所幫助。
相關(guān)文章
基于firefox實(shí)現(xiàn)ajax圖片上傳
這篇文章主要介紹了基于firefox實(shí)現(xiàn)ajax圖片上傳,大家都知道在FF下使用ajax是件挺困難的事情,今天給大家介紹的是完美解決這個(gè)問(wèn)題的方法,小伙伴可以參考下。2015-05-05
AJAX應(yīng)用實(shí)例之檢測(cè)用戶名是否唯一(實(shí)例代碼)
本文通過(guò)實(shí)例代碼給大家介紹了AJAX應(yīng)用實(shí)例之檢測(cè)用戶名是否唯一,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-09-09
ajax實(shí)現(xiàn)頁(yè)面加載和內(nèi)容刪除
這篇文章主要為大家詳細(xì)介紹了ajax實(shí)現(xiàn)頁(yè)面加載和內(nèi)容刪除的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
AJAX集天氣\IP\多國(guó)語(yǔ)言翻譯MP3(可同步LRC歌詞顯示)\萬(wàn)年歷查詢通
AJAX集天氣\IP\多國(guó)語(yǔ)言翻譯MP3(可同步LRC歌詞顯示)\萬(wàn)年歷查詢通...2007-09-09
js與jQuery實(shí)現(xiàn)的兼容多瀏覽器Ajax請(qǐng)求實(shí)例
這篇文章主要介紹了js與jQuery實(shí)現(xiàn)的兼容多瀏覽器Ajax請(qǐng)求,以實(shí)例形式分別講述了采用純js與jQuery實(shí)現(xiàn)的兼容多瀏覽器Ajax請(qǐng)求的方法,并對(duì)Ajax中出現(xiàn)的亂碼問(wèn)題進(jìn)行了一定的分析,需要的朋友可以參考下2014-11-11
理解jquery ajax中的datatype屬性選項(xiàng)值
jquery中ajax的dataType屬性用于指定服務(wù)器返回的數(shù)據(jù)類型,如果不指定,jQuery 將自動(dòng)根據(jù)HTTP包MIME信息來(lái)智能判斷,如果datatype選項(xiàng)不填寫(xiě)的話,會(huì)將返回的數(shù)據(jù)當(dāng)成字符串處理。2015-10-10
AJAX 請(qǐng)求區(qū)分 $_SERVER[''HTTP_X_REQUESTED_WITH''] 小解
關(guān)于這個(gè)內(nèi)容,很多人都有所了解.但從我搜索的內(nèi)容來(lái)看,他們只是略微看一下,根本不知道里面到底是什么情況.2011-06-06
服務(wù)端配置實(shí)現(xiàn)AJAX跨域請(qǐng)求
這篇文章主要介紹了服務(wù)端配置實(shí)現(xiàn)AJAX跨域請(qǐng)求的相關(guān)資料,需要的朋友可以參考下2015-02-02

