一、什么是跨域問題
在一個服務器A里放置了json文件,另一個服務器B想向A發(fā)送ajax請求,獲取此文件,會發(fā)生錯誤。
Chrome提示:
1
|
XMLHttpRequest cannot load ******. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'null' is therefore not allowed access. |
這就是跨域問題。解決方案有不少,比較好的是服務器端配置CORS,但要求服務器端做更改。如果在不需要更改服務器端的情況下解決呢?尤其是需要在本地測試的時候。
二、配置Nginx
打開nginx目錄下的conf文件夾。打開nginx.conf,將其中的http請求修改為:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
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/表示當請求api目錄時,轉(zhuǎn)向http://www.des.com/域名。
例如,請求:
http://127.0.0.1/api/ 就會轉(zhuǎn)向 http://www.des.com/
http://127.0.0.1/api/aaa/bbb/ 就會轉(zhuǎn)向 http://www.des.com/aaa/bbb/
這種由服務器轉(zhuǎn)發(fā)的請求,可以突破跨域的限制,因此ajax也可以正常工作。
注意: /api/ 不行寫成 /api。
http://www.des.com/ 也不能寫成 http://www.des.com
三、配置hosts
為了在本機測試看起來更像在目標服務器上測試,可以設(shè)置系統(tǒng)的hosts文件。
每個系統(tǒng)(windows、Linux、Mac OS)都有hosts文件,它是本地的域名解析器。
通常,我們請求一個域名,如www.baidu.com,首先要向域名服務器請求百度的IP地址,然后再根據(jù)IP地址來訪問。
也可以不需要咨詢域名服務器,直接在本地的hosts鍵入百度的IP地址。
例如
252.192.0.15 www.baidu.com
這樣,系統(tǒng)會先從hosts文件里搜索IP地址。
Windows下的hosts文件位于:C:\Windows\System32\drivers\etc
打開后,添加
1
|
127.0.0.1 www.des.com |
則,每次訪問www.des.com,就會鏈接到本地。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。