一、什么是跨域問(wèn)題
在一個(gè)服務(wù)器A里放置了json文件,另一個(gè)服務(wù)器B想向A發(fā)送ajax請(qǐng)求,獲取此文件,會(huì)發(fā)生錯(cuò)誤。
Chrome提示:
XMLHttpRequest cannot load ******. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'null' is therefore not allowed access.
這就是跨域問(wèn)題。解決方案有不少,比較好的是服務(wù)器端配置CORS,但要求服務(wù)器端做更改。如果在不需要更改服務(wù)器端的情況下解決呢?尤其是需要在本地測(cè)試的時(shí)候。
二、配置Nginx
打開(kāi)nginx目錄下的conf文件夾。打開(kāi)nginx.conf,將其中的http請(qǐng)求修改為:
http { include mime.types; server { listen 80; server_name localhost; charset UTF-8; location / { root html; index index.html index.htm; } # Avoid CORS and reverse proxy settings location /api/ { # [2] proxy_http_version 1.1; proxy_pass http://www.des.com/; # [3] add_header Access-Control-Allow-Origin *; add_header Access-Control-Allow-Methods "POST, GET, OPTIONS"; add_header Access-Control-Allow-Headers "Origin, Authorization, Accept"; add_header Access-Control-Allow-Credentials true; } }}
注意粗體字的部分,/api/表示當(dāng)請(qǐng)求api目錄時(shí),轉(zhuǎn)向http://www.des.com/域名。
例如,請(qǐng)求:
http://127.0.0.1/api/ 就會(huì)轉(zhuǎn)向 http://www.des.com/
http://127.0.0.1/api/aaa/bbb/ 就會(huì)轉(zhuǎn)向 http://www.des.com/aaa/bbb/
這種由服務(wù)器轉(zhuǎn)發(fā)的請(qǐng)求,可以突破跨域的限制,因此ajax也可以正常工作。
注意: /api/ 不行寫(xiě)成 /api。
http://www.des.com/ 也不能寫(xiě)成 http://www.des.com
三、配置hosts
為了在本機(jī)測(cè)試看起來(lái)更像在目標(biāo)服務(wù)器上測(cè)試,可以設(shè)置系統(tǒng)的hosts文件。
每個(gè)系統(tǒng)(windows、Linux、Mac OS)都有hosts文件,它是本地的域名解析器。
通常,我們請(qǐng)求一個(gè)域名,如www.baidu.com,首先要向域名服務(wù)器請(qǐng)求百度的IP地址,然后再根據(jù)IP地址來(lái)訪問(wèn)。
也可以不需要咨詢域名服務(wù)器,直接在本地的hosts鍵入百度的IP地址。
例如
252.192.0.15 www.baidu.com
這樣,系統(tǒng)會(huì)先從hosts文件里搜索IP地址。
Windows下的hosts文件位于:C:/Windows/System32/drivers/etc
打開(kāi)后,添加
127.0.0.1 www.des.com
則,每次訪問(wèn)www.des.com,就會(huì)鏈接到本地。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。
新聞熱點(diǎn)
疑難解答
圖片精選