前言
- 记录下
Nginx 部署Vue 项目刷新404 的解决方案,遇到了两次,route 用的是history 路由模式,动态路由:
{
path: '/article/:blogId',
name: 'blog',
component: blog
}
location / {
root /usr/local/nginx/html/blog/;
index index.html index.htm;
}
data:image/s3,"s3://crabby-images/dd164/dd164f6fe4bc7ae7e9404378d410d1e8f643d1d7" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/fe3a4/fe3a4530f775b2c121cb43887dbcea833008444c" alt="在这里插入图片描述"
location / {
root /usr/local/blog/;
index index.html index.htm;
try_files $uri $uri/ /index.html;
}
data:image/s3,"s3://crabby-images/3af2d/3af2def80e3ef051d592b9fb1348fa874326acc5" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/fe3a4/fe3a4530f775b2c121cb43887dbcea833008444c" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/55a1d/55a1df866ab91791f8847d457c94b62e366f6065" alt="在这里插入图片描述"
好吧,记录下两次的解决方案,先行感谢两位大佬给的启发
第一次
网站没有申请二级域名,部署了多项目,所以想的是添加项目前缀'/blog' 访问,比如这个:
https://www.coisini.club/blog
mode: 'history',
routes: [
{
path: '/blog',
component: home,
children: [
{
path: '/',
component: index
},
{
path: '/blog/article/:blogId',
name: 'blog',
component: blog
},
....
出错打包配置
assetsPublicPath: './',
正确打包配置
assetsPublicPath: '/blog/',
- 就是这个
assetsPublicPath 资源路径忘记配置惹了N 多麻烦, 留下了不学无数的眼泪,如果有遇到同样场景的同学记得核实
data:image/s3,"s3://crabby-images/99e1e/99e1e91a0cdc9e2f5f36e7b3936395fd6bf6a71e" alt="在这里插入图片描述"
有两种配置方式,均验证有效
方式一:
location /blog {
root /usr/local/nginx/html/;
index index.html index.htm;
try_files $uri $uri/ /blog/index.html;
}
方式二:
location /blog {
root /usr/local/nginx/html/;
index index.html index.htm;
try_files $uri $uri/ @rewrites;
}
location @rewrites {
rewrite ^/(blog)/(.+)$ /$1/index.html last;
}
data:image/s3,"s3://crabby-images/fe0b4/fe0b43ca852f55ce83e786f0e490d748bfdba7bb" alt="在这里插入图片描述"
第二次
网站申请了二级域名,之前的配置都要修改了,比如这样:
https://blog.coisini.club/
mode: 'history',
routes: [
{
path: '/',
component: index
},
{
path: '/article/:blogId',
name: 'blog',
component: blog
},
....
assetsPublicPath: './',
server {
listen 443 ssl;
server_name blog.coisini.club;
location / {
root /usr/local/blog/;
index index.html index.htm;
}
}
data:image/s3,"s3://crabby-images/8c229/8c229f6520ba7432afd6ffac02b2533ad6e4355e" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/55ba9/55ba9b4dc4bf06d9ef6655a17e77f678837d3c48" alt="在这里插入图片描述"
- 然后照例请教度娘,度娘说
try_files $uri $uri/ /index.html;
location / {
root /usr/local/blog/;
index index.html index.htm;
try_files $uri $uri/ /index.html;
}
data:image/s3,"s3://crabby-images/80c00/80c00e1a6e49cced7561ab24fab001d3de327222" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/99e1e/99e1e91a0cdc9e2f5f36e7b3936395fd6bf6a71e" alt="在这里插入图片描述"
assetsPublicPath: '/',
location / {
root /usr/local/blog/;
index index.html index.htm;
try_files $uri $uri/ /index.html =404;
autoindex on;
}
data:image/s3,"s3://crabby-images/563d8/563d8890f9f71d8c3db7f20b13626a058ab4af9a" alt="在这里插入图片描述"
- End -
- 个人笔记 -
- 仅供参考-
|