记录Nginx部署Vue项目的流程,以及部署后前端出现问题的解决方案。
一、安装nginx
二、部署流程
三、解决前端路由history模式刷新页面404的问题
四、Nginx解决前端项目打包缓存问题
五、后话
http://nginx.org/ ,找到页面右下角的download,例如选nginx-1.22.1,点击下载,解压放到你心仪的盘符文件夹中。
conf:里面有配置文件nginx.conf
html:放打包好的Vue项目,即前端dist包。
将前端打包的dist文件夹复制进来,dist重命名为前端项目的英文名称
nginx.exe:nginx启动项
任选其一即可
1、按Win + R,输入cmd,回车
2、在Nginx根目录url中,清空所有,输入cmd,回车
3、在Nginx根目录按住Shift + 鼠标右键,点击 在此处选择Powershell 窗口
文件路径:nginx-1.22.1\conf\nginx.conf
修改location对象的 root html/项目名称 例如 html/vitelearn;
server {
listen 9900;
# 自定义端口号,找没有被占用的。怎么查看端口是否已被占用,请看下面Windows命令
location / {
root html/vitelearn; # 对应nginx-1.22.1\html\项目名称
}
}
Nginx.conf 完整代码如下
#user nobody;
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
gzip on;
gzip_min_length 1k; #最小压缩大小
gzip_buffers 4 16k; #压缩缓冲区
gzip_http_version 1.0; #压缩版本
gzip_comp_level 2; #压缩等级
gzip_types text/plain text/css text/xml text/javascript application/json application/x-javascript application/xml application/xml+rss font/ttf font/otf imagesvg+xml;#压缩类型
server {
listen 9900;
location / {
root html/vitelearn;
index index.html index.htm;
try_files $uri $uri/ /index.html;
}
#error_page 404 /404.html;
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
}
不知道怎么进命令行终端,请看上面 如何进入命令行终端去敲命令
netstat -aon|findstr "XXX" 检查端口是否被占用 例如: netstat -aon|findstr "9900"
taskkill /f /t /im nginx.exe 杀死所有nginx服务进程(其中包括端口)
每次打前端dist包,先停止再重启
nginx -s stop 停止
start nginx 启动
nginx -s reload 重载
补充说明:前端dist包没变动,只修改了nginx配置,此时需要重新加载最新的nginx配置
说明:即没#号的。需要在nginx添加一行代码,添加完保存。
nginx配置修改如下:
server {
location / {
root html/vitelearn;
index index.html index.htm;
try_files $uri $uri/ /index.html; # 加这一句
}
}
两种情况(根据不同情况选择对应的方法,二选一即可):
1、如果前端dist包有变动,nginx配置也变动,需要停止并重启nginx
nginx -s stop 停止
start nginx 启动
2、如果前端dist包没变动,nginx配置有变动,执行nginx重载即可
nginx -s reload
再次刷新部署后的页面就不会出现404错误了。
Vue2/Vue3不同版本的history设置如下
在router/index.js 设置路由模式
export default new Router({
routes:[....]
mode: "history",
});
在router/index.ts,封装路由的页面,引入history方法
import { createWebHistory } from 'vue-router'
const router = createRouter({
history: createWebHistory(),
routes,
})
说明:它会在url多一个#,比较难看,但它不需要在nginx配置代码,同时它刷新页面不会报404.
Vue2/Vue3不同版本的hash设置如下
export default new Router({
routes:[....]
mode: "hash",
});
import { createWebHashHistory } from 'vue-router'
const router = createRouter({
history: createWebHashHistory(),
routes,
})
用文本形式打开 nginx-1.22.1\conf\nginx.conf,在location中加入这个if判断。location的其他配置不需要删除
server {
location / {
if ($request_filename ~* .*\.(?:htm|html)$)
{
add_header Cache-Control "no-store, no-cache";
}
}
做个笔记,方便下次忘了过来查阅。小伙伴们,如果你们学完一个东西或者很有心得,有空了可以将新学的知识点整理成自己的笔记,下次遇到就无需花这么多时间查阅,而是快速回顾,精准打击,逐一击破。
加油,慢慢点亮自己的技能树。
参考这位大佬的文章: https://www.cnblogs.com/Yan3399/p/17202859.html,感恩感谢这位大佬。