nginx运行vue项目的dist文件

news2024/9/23 23:30:21

目录

  • 1、安装nginx
    • 1.1、nginx常用命令
    • 1.2、将nginx注册为Windows系统服务
  • 2、拷贝文件
  • 3、修改配置文件
  • 4、访问

1、安装nginx

官网下载:http://nginx.org/en/download.html在这里插入图片描述
下载完之后直接解压即可在这里插入图片描述
注:存放路径最好不要有中文、空格

1.1、nginx常用命令

# 启动
start nginx
# 关闭
nginx -s quit
# 重新加载
nginx -s reload

# 检查端口是否被占用:
netstat -ano | findstr 0.0.0.0:80 
或
netstat -ano | findstr "80"

1.2、将nginx注册为Windows系统服务

参考博客:https://blog.csdn.net/hon_vin/article/details/133717846

2、拷贝文件

dist整个文件夹拷贝到nginx根目录下的html文件夹中

这里需要将 vue.config.js 中的 publicPath 设为 /dist

3、修改配置文件

配置文件如下:

server {
	# 监听端口
	listen       80;
	# 服务名、域名+
	server_name  localhost;

	location / {
		root   html;
		index  index.html index.htm;
	}

	# 这里的dist就是之前拷贝到html目录下的文件夹名,可自行修改(目录名修改后将此处的dist也同步修改)
	location /dist{
		alias html/dist/;
		index  index.html index.htm;
		# 这里是为了防止刷新页面时404(下面有解释)
		try_files  $uri $uri/ /dist/index.html;
	}

	# 这里是为了防止刷新页面时404(下面有解释)
	location @router {
		rewrite ^.*$ /dist/index.html;
	}
}

首先解释下为什么会有刷新页面之后出现404的情况:

因为项目打包完部署后,地址栏的地址只是vue的路由,并不是实际的文件目录地址。
而所有的路由都是依赖于SPA单页应用的index.html,所以当页面刷新时,按照地址栏的地址,找不到对应的文件,就出现了404。

解决办法: 在nginx里配置 try_files,如果按照路径找不到文件时,就统一去找index.html

接着解释下try_files的作用:

try_files的作用是按顺序检查文件是否存在,举个例子:
假设我们的访问地址为 http://localhost:80/dist/login

1. 开始先通过 alias 确定访问的文件路径为 html/dist/
2. 再通过 try_files 配置,首先从 html/dist/ 下面找 $uri(login 这个文件)
3. 如果没找到 login 文件,再去找 $uri/ (/login/ 这个文件夹目录)
4. 如果还是没找到,就会重定向到 @router
5. 在定义的 @router 中,指向 /dist 目录下的 index.html 文件

4、访问

访问 http://localhost:80/dist 即可

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1075096.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

接口测试必备技能

接口测试,其实并没有那么可怕,但是作为测试人员也是必不可少的技能。 接口分为:内部接口和外部接口。 内部接口:是浏览器与服务器的接口。这个很容易理解,web开发一般分前端和后端,前端开发人员用html/css…

FusionCharts Suite XT v3.21 Crack

FusionCharts Suite XT v3.21 在圆环图和饼图上将图例和数据值显示为百分比或绝对值。 2023 年 10 月 4 日 - 15:15新版本 特征 通过允许用户将图例和数据值显示为百分比或绝对值,改进了圆环图和饼图。 添加了一个新功能,可以删除任何可能导致代码错误的…

MySQL-2(14000字详解)

一: 数据库约束 在 MySQL 中,约束是用于限制数据库表中数据的规则或条件。它们是为了保证数据的完整性和一致性。MySQL 提供了多种约束类型,包括 NOT NULL、UNIQUE、DEFAULT、PRIMARY KEY、FOREIGN KEY 和 CHECK等等 NOT NULL 约束&#xf…

【Redis】String内部编码方式

String内部编码方式 int: 8个字节的长整型embstr: 小于等于39个字节的字符串raw: 大于39个字节的字符串

Visual Studio 2022 修改字符集的方法

在射频识别技术课程实验过程中发现的报错问题,搞了半天才找到原因,是字符集设置有问题。下图为报错: 根本原因是默认的字符编码集是Unicode。 改成使用多字节字符集就好了。以下为修改方法。

Jetpack:003-布局中组件的对齐方式

文章目录 1. 概念介绍2. 使用方法2.1 行布局中的对齐方式2.2 列布局中对齐方式 3. 示例代码4. 内容总结 我们在上一章回中介绍了Jetpack中的页面和布局,本章回中将介绍 布局中组件的对齐方式。闲话休提,让我们一起Talk Android Jetpack吧 1. 概念介绍 …

大数据软件系统开发框架

大数据处理框架是用于处理大规模数据集的软件工具和平台,它们可以帮助分析、存储和处理庞大的数据量。以下是一些常见的大数据处理框架,希望对大家有所帮助。北京木奇移动技术有限公司,专业的软件外包开发公司,欢迎交流合作。 1.A…

pytorch_神经网络构建3

文章目录 卷积神经网络实现卷积层,池化层池化层:数据标准化AlexNet卷积网络深层网络结构vgggoogleNet网络结构ResNet网络结构DensNet网络结构训练卷积神经网络会遇到的一些问题学习率衰减 卷积神经网络 前面讲述了逻辑回归分类,模拟函数回归问题,单层,深层网络,它们以点和向量…

基于SSM的开心农家乐系统设计与实现

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:采用JSP技术开发 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目&#x…

Tomcat安装

tomcat.apache.org 下载Tomcat8 根据系统选择安装包 配置JAVA_HOME 解压文件,启动Tomcat 启动成功,默认占用8080端口 MAC版本在bin目录输入./startup.sh启动Tomcat 访问Tomcat:localhost:8080 根据tomcat版本选择servlet版本 tomc…

OpenWRT配置SFTP远程文件传输,实现数据安全保护

文章目录 前言1. openssh-sftp-server 安装2. 安装cpolar工具3.配置SFTP远程访问4.固定远程连接地址 前言 本次教程我们将在OpenWRT上安装SFTP服务,并结合cpolar内网穿透,创建安全隧道映射22端口,实现在公网环境下远程OpenWRT SFTP&#xff…

运算符

目录 算术运算符 比较运算符 逻辑运算符 位运算符 运算符的优先级 MySQL从小白到总裁完整教程目录:https://blog.csdn.net/weixin_67859959/article/details/129334507?spm1001.2014.3001.5502 数据库中的表结构确立后,表中的数据代表的意义就已经确定。而…

[护网杯 2018]easy_tornado 解析

打开网页有三个链接,依次点开之后获得一个fllllllllllllag一个render和一个MD5加密格式 之后尝试去访问/fllllllllllllag 直接跳出报错界面。 但这个报错界面居然是可以改的 试着注入一下 看了师傅的wp发现好像没有,要从框架入手 框架就是标题的torna…

[极客大挑战 2020]Roamphp2-Myblog - 伪协议+文件上传+(LFIZIP)||(LFIPhar)【***】

[极客大挑战 2020]Roamphp2-Myblog 1 解题流程1.1 分析1.2 解题1.3 中场休息——再分析1.3.1 浅层分析1.3.2 难点疑惑1.3.3 深度分析 1.4 重整旗鼓——再战1.4.1 解法一:zip伪协议1.4.2 解法二:phar伪协议 2 总结展望 1 解题流程 1.1 分析 1、点击logi…

OpenCV4(C++)—— 图片的基本尺寸变换

文章目录 一、resize(缩放)二、filp(翻转)三、裁剪四、拼接 一、resize(缩放) void cv::resize(cv::InputArray src, // 输入图像cv::OutputArray dst, // 输出图像cv::Size dsize, …

C++对象模型(6)-- 数据语义学:继承的对象布局(含虚函数)

1、单个类带虚函数的对象布局 当类含有虚函数时,在实例化对象时会产生一个虚函数表指针,这个虚函数表指针通常在对象的开头位置。 class Base { public:int x;int y;virtual void virFunc() { } }; 对象布局如下: 2、单一继承父类带虚函数…

ZYNQ的程序固化

03-ZYNQ学习(启动篇)之程序的固化_zynq ps网口-CSDN博客 ZYNQ启动之后, PS_POR_B 复位引脚置低后,硬件立即对引导带引脚进行采样,并可选择启用 PS 时钟 PLL。然后,PS开始执行片上ROM中的BootROM代码来引导…

UniApp项目实践HelloUni继续快速小步快跑中,前面是大上海吗

效果镇楼 本来想着稍微刷点课程就完活的,结果还是到这个点了。宝贵的时间啊 直接代码干就是了,参考如下链接; UniApp实践业务项目

使用Resource Hacker编辑DLL文件

Resource Hacker下载 链接:https://pan.quark.cn/s/8e18988d49aa 操作 打开resource hacker软件 打开文件 修改 编译,点击绿色按钮 提示成功 将编译后的文件另存为即可

C语言纳秒级计时

C语言纳秒级计时 文章目录 C语言纳秒级计时函数介绍示例代码参考 函数介绍 C语言中常用的clock()函数只能精确到毫秒级,对应的数据类型是clock_t。 C11标准中提供了纳秒级别定时器:timespec_get()函数与timespec()类型。 struct timespec{time_t tv_s…