Nginx转发地址解决跨域问题

什么是跨域问题

在一个服务器A里放置了json文件,另外一个服务器B想向A发送ajax请求,获取此文件,会发生错误。html

Chrome提示:linux

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

打开nginx目录下的conf文件夹。打开nginx.conf,将其中的http请求修改成:ajax

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目录时,转向http://www.des.com/域名。
例如,请求:sql

http://127.0.0.1/api/ 就会转向 http://www.des.com/json

http://127.0.0.1/api/aaa/bbb/ 就会转向 http://www.des.com/aaa/bbb/windows

这种由服务器转发的请求,能够突破跨域的限制,所以ajax也能够正常工做。api

注意:/api/ 不行写成 /api。 跨域

http://www.des.com/ 也不能写成 http://www.des.com服务器

配置hosts

为了在本机测试看起来更像在目标服务器上测试,能够设置系统的hosts文件。
每一个系统(windows、linux、Mac OS)都有hosts文件,它是本地的域名解析器。
一般,咱们请求一个域名,如www.baidu.com,首先要向域名服务器请求百度的IP地址,而后再根据IP地址来访问。

也能够不须要咨询域名服务器,直接在本地的hosts键入百度的IP地址。例如
252.192.0.15 www.baidu.com

这样,系统会先从hosts文件里搜索IP地址。

Windows下的hosts文件位于:C:\Windows\System32\drivers\etc

打开后,添加

127.0.0.1 www.des.com

则,每次访问www.des.com,就会连接到本地。

相关文章
相关标签/搜索