主頁(yè) > 知識(shí)庫(kù) > 有關(guān)Ajax跨域問(wèn)題的兩種解決方法

有關(guān)Ajax跨域問(wèn)題的兩種解決方法

熱門(mén)標(biāo)簽:老虎郵局地圖標(biāo)注點(diǎn) 目標(biāo)三維地圖標(biāo)注 青海醫(yī)療智能外呼系統(tǒng)怎么樣 科智聯(lián)智能電銷機(jī)器人 上海浦東百度地圖標(biāo)注中心注冊(cè) 徐州電銷卡外呼系統(tǒng)供應(yīng)商 外呼系統(tǒng)獲取客戶手機(jī)號(hào) 百靈鳥(niǎo) 襄陽(yáng)外呼系統(tǒng)接口

概述

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ì)大家有所幫助。

您可能感興趣的文章:
  • AJAX的跨域訪問(wèn)-兩種有效的解決方法介紹
  • jquery ajax跨域解決方法(json方式)
  • ajax跨域請(qǐng)求js拒絕訪問(wèn)的解決方法
  • IE9版本以下ajax 跨域問(wèn)題可行解決方法

標(biāo)簽:荊州 佛山 商洛 股票 紅河 辛集 揭陽(yáng) 咸寧

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《有關(guān)Ajax跨域問(wèn)題的兩種解決方法》,本文關(guān)鍵詞  有關(guān),Ajax,跨域,問(wèn),題的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《有關(guān)Ajax跨域問(wèn)題的兩種解決方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于有關(guān)Ajax跨域問(wèn)題的兩種解決方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章