首頁  >  問答  >  主體

vue.js - vue-router開啟HTML5的history模式後nginx配置

因為在eagle201510項目下面有很多子項目,嘗試了多種配置方法都不能共存

我希望是這樣的:

server {
        listen       80;
        server_name  192.168.10.91;
        root   "E:/UED/eagle/branch/eagle201510";
        location / {
            index  index.html index.htm index.php;
            #autoindex  on;
        }
        location ^~ /m-example/ {
            root   "E:/UED/eagle/branch/eagle201510/m-example";
            try_files $uri $uri/ /index.html =404;
        }
        location ~ \.php(.*)$ {
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            fastcgi_split_path_info  ^((?U).+\.php)(/?.+)$;
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
            fastcgi_param  PATH_INFO  $fastcgi_path_info;
            fastcgi_param  PATH_TRANSLATED  $document_root$fastcgi_path_info;
            include        fastcgi_params;
        }
}

m-example目錄是使用vue-router開發的單頁應用,需要單獨配置,但這種方式m-example並不能正常載入
載入的js,css都變成了html
console

#
vendors.js:1 Uncaught SyntaxError: Unexpected token <
main.js:1 Uncaught SyntaxError: Unexpected token <
index.html:6 Resource interpreted as Stylesheet but transferred with MIME type text/html: "http://192.168.10.91/m-example/dist/main.css".

如果配置改成這樣:

server {
        listen       80;
        server_name  192.168.10.91;
        root   "E:/UED/eagle/branch/eagle201510";
        location / {
            root   "E:/UED/eagle/branch/eagle201510/m-example";
            try_files $uri $uri/ /index.html =404;
        }
        location ~ \.php(.*)$ {
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            fastcgi_split_path_info  ^((?U).+\.php)(/?.+)$;
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
            fastcgi_param  PATH_INFO  $fastcgi_path_info;
            fastcgi_param  PATH_TRANSLATED  $document_root$fastcgi_path_info;
            include        fastcgi_params;
        }
}

就正常了。但是其它項目又無法訪問了。 。 。

曾经蜡笔没有小新曾经蜡笔没有小新2713 天前1077

全部回覆(2)我來回復

  • 过去多啦不再A梦

    过去多啦不再A梦2017-05-16 17:17:13

    新增一個server配置項目解決,如下:

    server {
            listen       80;
            server_name  www.m-example.com;
            root   "E:/UED/eagle/branch/eagle201510/m-example";
            location / {
                try_files $uri $uri/ /index.html =404;
            }
    }

    回覆
    0
  • 过去多啦不再A梦

    过去多啦不再A梦2017-05-16 17:17:13

    把所有沒有後綴名的請求如果404都跳到index.html

    location / {
      error_page  404  /index.html; 
    }

    回覆
    0
  • 取消回覆