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; includefastcgi_params;}}
m-example目錄是使用vue-router開發的單頁應用,需要單獨配置,但這種方式m-example并不能正常加載加載的js,css都變成了htmlconsole
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; includefastcgi_params;}}
就正常了。但是其它項目又無法訪問了。。。
問題解答
回答1:添加一個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;}}回答2:
把所有沒有后綴名的請求如果404都跳轉到index.html
location / { error_page 404 /index.html; }
相關文章:
1. java - yuicompressor-maven-plugin 合并可用卻不壓縮, 哪配置不對?2. docker images顯示的鏡像過多,狗眼被亮瞎了,怎么辦?3. linux - mysql源碼安裝遇到的問題4. dockerfile - [docker build image失敗- npm install]5. mysql - msyql 判斷字段不為空 簡單方法6. docker gitlab 如何git clone?7. 關docker hub上有些鏡像的tag被標記““This image has vulnerabilities””8. javascript - Vue 自定義控件v-model雙向綁定9. angular.js使用$resource服務把數據存入mongodb的問題。10. css - chrome下a標簽嵌套img 顯示會多個小箭頭?
