vue在开发中,可以通过自带的脚手架配置实现跨域访问,但是打包时不会将这部分配置文件载入,这样会导致上了生产环境出现跨域访问的问题。在网上查过一些解决跨域的问题,都没太搞明白,然后就想采用nginx将服务请求转发来实现,经过一天的摸索,终于搞定了。

        最开始的的nginx配置如下:

server {
        listen       80;
        server_name  abc.def.com;
        index index.html;
        location /  {
            root /usr/share/nginx/html/app;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }

        这个配置是将所有访问“abc.def.com”的请求都转发到对应的路径下,然后请求服务的链接为:http://w.xyz.com/projectname/rs/service/servicename(采用resteasy开发的Java服务),就会产生跨域问题。

        之前解决过一次跨域问题,就是将vue的代码放到java工程的WwbRoot目录下,请求链接将前缀去掉,改为:/projectname/rs/servicename,这样因为成了本地请求,就避免了跨域访问。

        然后基于以上两点,将nginx进行改造,如下:

server {
        listen       80;
        server_name  abc.def.com;
        index index.html;
        location ~ (/static/|index.html)  {
            root /usr/share/nginx/html/app;
        }
        location ~ /projectname/ {
            proxy_pass   http://w.xyz.com;
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }

        将之前的location进行改造,规定只有访问前缀是/static/或者index.html这两种情况,才会转发到本地的vue目录下,保证了前端可以正常访问页面。

        然后新增一个location,规定/projectname/开头的的请求,会被转发到http://w.xyz.com这个地址。

        这样就实现了vue的跨域访问了。

        补充一点,上面这种配置有一个弊端,就是遇到链接中带参数的、或者采用vue路由模式跳转的页面,直接访问是无法打开的。比如:

        http://abc.def.com/news?param1=1000&param2=16919

        这种情况因为news是一个路由,按照第二种配置,只有static和index.html才会被转发,会导致这种情况报404错误

        所以需要改为如下配置:

server {
        listen       80;
        server_name  abc.def.com;
        index index.html;
        location ~ /projectname/ {
            proxy_pass   http://w.xyz.com;
        }
        location / {
            root /usr/share/nginx/html/app;
            try_files $uri /index.html;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }

        将服务跳转的location放在第一位,这样按照顺序匹配,先将服务请求进行转发,然后将剩余的所有请求均转发到本地vue目录,还需要增加try_files $uri /index.html;这句话大致是说,不管什么路径请求,都会转发到index.html页面中,然后再根据后面的路由及参数,由页面进行处理。