vue打包部署 刷新404

1、打包vue项目

npm run build

2、部署一个nginx来做服务器,下载安装就不多说了,历史教程也有。重点是配置静态资源。

打开conf/nginx.conf文件,端口默认80要改可以改下。主要是要把root改成你打包网站的存放目录。

    server {
        listen       80;
        server_name  localhost;

        location / {
            root   D:\发布网站\project;
            index  index.html index.htm;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }

改完配置把nginx启动起来即可。

 

接下来刷新页面会出现404的现象,我提供几个解决方案。

方案一

去掉这行代码。url上会出现带有#的地址。

mode: 'history',

 

方案二

在nginx配置文件中调整下,没试过,我用的是方案三。

location /{
  root   /data/nginx/html;
  index  index.html index.htm;
  if (!-e $request_filename) {
    rewrite ^/(.*) /index.html last;
    break;
  }
}

方案三

也是调整nginx配置文件,红色字体为添加的内容,即可实现刷新页面。

        location / {
            root   D:\发布网站\project;
            #需要指向下面的@router否则会出现vue的路由在nginx中刷新出现404
            try_files $uri $uri/ @router;
            index  index.html index.htm;
        }
        #对应上面的@router,主要原因是路由的路径资源并不是一个真实的路径,所以无法找到具体的文件
        #因此需要rewrite到index.html中,然后交给路由在处理请求资源
        location @router {
            rewrite ^.*$ /index.html last;
        }

 

参考链接:https://segmentfault.com/a/1190000016653688

 

转载于:https://my.oschina.net/uwith/blog/3054629

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值