路由器的两种工作模式及快速通过express搭建微型服务器流程,解决刷新页面服务端404的问题

news2025/2/23 13:36:59

history模式与hash模式

首先这个#叫做hash,最大的特点就是不会随的http请求,发给服务器。

默认的模式是hash模式,如果想要修改,可以在router里面的index.js中配置mode属性,

 

它们俩直接的区别最明面上的有没有#和history模式要比hash模式的兼容性稍微差点。还有上线区别。

 npm run build打包,然后生成一个dist文件。

为什么我们要打包?

浏览器不识别.vue文件,需要webpack打包成html,让浏览器能够识别 

并且打包完的文件,需要在服务器中部署

现在我们使用express框架快速搭建一个微型的服务器

1.新建一个文件夹demo

2.npm init

3.给包取一个名字,就叫lesson

下面的内容都直接回车就可以了

 4.npm i express

5.文件夹中,右击新建一个server.js

6.在文件中输入内容

const express=require('express')

const app=express()

app.get('/person',(req,res)=>{
    res.send({
        name:'tom',
        age:19
    })
})

app.listen(5005,(err)=>{
    if(!err) console.log('服务器请求成功');
})

 7.开启服务器 node server.js

然后把我们保存好的静态页面放到static里面。

如果我们需要在服务器中访问到它,需要添加 app.use(express.static(__dirname+'/static'))

停掉服务器就能重新访问到这个页面了

 然后把我们当当脚手架生成的文件放进去,重新打开,就可以了

然后就发现,你点击是没有关系的,但是你刷新,就直接废了

 因为,你刷新相当于发送网络请求,但你配置的服务器下是没有这个配置的,只有/person

这个history模式就是有这个模式的,而hash模式是没有这个问题的

 当然,这不是很美观,需要我们的后端程序员配合,这里提供一个node,中间件的方案

connect-history-api-fallback通过这个解决connect-history-api-fallback - npm (npmjs.com)

 

 然后引用,配置它

注意必须要在静态资源之前(app.use(express.static(__dirname+'/static')))去用它

app.use(history())

 然后重启服务器,就可以使用它了

 总结

* 对于一个url来说,什么是hash值?—— #及其后面的内容就是hash值。
* hash值不会包含在 HTTP 请求中,即:hash值不会带给服务器。
* hash模式:
  1. 地址中永远带着#号,不美观 。
  2. 若以后将地址通过第三方手机app分享,若app校验严格,则地址会被标记为不合法。
  3. 兼容性较好。
* history模式:
  1. 地址干净,美观 。
  2. 兼容性和hash模式相比略差。
  3. 应用部署上线时需要后端人员支持,解决刷新页面服务端404的问题。

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

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

相关文章

Python第三方库安装

看见更大的Python世界 Python社区PyPI The Python Package Index PyPI: Python Package Index PSF维护的展示全球Python计算生态的主站 学会检索并利用PyPI,找到合适的第三方库开发程序 实例:开发与区块链相关的程序 第1步:在pypi.org…

【服务器数据恢复】EVA存储数据硬盘掉线导致LUN不可用的数据恢复

服务器数据恢复环境: HP-EVA存储环境:EVA某型号控制器EVA扩展柜FC硬盘。 服务器故障: EVA存储中两块磁盘掉线导致存储中某些LUN丢失不可用。 服务器数据恢复过程: 1、首先对故障存储中所有磁盘做物理故障检测,经过…

在Spring Boot微服务使用RedisTemplate操作Redis

记录:400 场景:在Spring Boot微服务使用RedisTemplate操作Redis缓存和队列。 使用ValueOperations操作Redis String字符串;使用ListOperations操作Redis List列表,使用HashOperations操作Redis Hash哈希散列,使用SetO…

基于LNMP架构搭建网站

一、编译安装Nginx 服务 1、编译安装Nginx 服务的操作步骤 systemctl stop firewalld systemctl disable firewalld setenforce 01.1 安装依赖包 yum -y install pcre-devel zlib-devel gcc gcc-c make1.2 创建运行用户 useradd -M -s /sbin/nologin nginx1.3 编译安装 cd…

Claude注册安装教程【403 Forbidden】

Claude注册安装教程 尝试注册Claude的兄弟需要注意,最后一步需要科学上网 本来打算看看csdn,结果可能是时效性,和我情况不一样 按照他们的意思,点击add a stack 就进去了,我却被403 这个时候我就搜索stack,…

钢网是SMT生产使用的一种工具,如何制作?

钢网是SMT生产使用的一种工具,其主要功能是将锡膏准确地涂敷在有需要焊接的PCB焊盘上。 钢网的好坏,直接影响印刷工作的质量,目前一般使用的金属钢网,是由薄薄的、带有小孔的金属板制作成的,在开孔处,锡膏…

React中Context的使用,跨组件传值

目录Context 是什么?使用ContextXxx.Provider正式使用Context中的数据Context 是什么? Context 提供了一个无需为每层组件手动添加 props,就能在组件树间进行数据传递的方法。 在一个典型的 React 应用中,数据是通过 props 属性自…

容器镜像的设计原理

1 概述: 1.1 历史概要 2016年,Docker制定了镜像规范v2,并在Docker 1.10中实现了这个规范。镜像规范v2分为Schema 1和Schema 2。 Schema 1主要兼容使用v1规范的Docker客户端(从2017年2月起,镜像规范v1不再被Registry支…

云计算基础——云服务

目录 云服务概述 云服务简介 云服务的产生和发展 云服务产生的前提: 接入云端的主要前端工具: 云服务的优缺点 优点 缺点 云服务的类型 SaaS PaaS IaaS 云部署模型 云服务概述 云服务简介 云计算通过使计算分布在大量的分布式计算机上&…

在线旅游变局:新老玩家的攻与防、危与机

配图来自Canva可画 五一小长假未到,大学生、职场人就早早制定了旅游路线,准备了旅游装备,还预订了机票和酒店。这边消费者们旅游之心急不可待,那边各地文旅局发布旅游消费券、完善旅游设施配套、花式宣传本地特色,使浑…

城市轨道交通列车时刻表优化问题【最优题解】

文章目录城市轨道交通列车时刻表优化问题思路文章底部城市轨道交通列车时刻表优化问题 最新进度在文章最下方卡片,加入获取思路数据代码论文:2023十三届MathorCup交流 (第一时间在CSDN分享,文章底部) 题目为数据分析类题目。列车时刻表优化…

基于.Net开源Html解析器,此外还支持SVG、XML等格式

今天给大家推荐一个Html解析器,可以用于网络爬虫Html源码的解析、Html源码编辑等场景。 项目简介 这是一个基于.Net开发的,Html代码解析器,支持通过C#实现类似Jquery的方式来解析Html源码、节点创建、节点删除、节点修改、属性的添加修改等&…

【算法与数据结构】3 知行合一,线性查找的自定义类测试

欢迎来到爱书不爱输的程序猿的博客, 本博客致力于知识分享,与更多的人进行学习交流 本文收录于算法与数据结构体系专栏,本专栏对于0基础者极为友好,欢迎与我一起完成算法与数据结构的从0到1的跨越 线性查找的测试应用1.前言2.使用自定义类测试2.1⛏创建Student类并测…

记录一下verilog重复例化的两种方式

文章目录0 前言1 for循环方式例化方法2 数组的方式例化4 一些其他的技巧0 前言 这段时间例化了挺多mem,过程中也了解到了一些新的东西,在这里记录一下 1 for循环方式例化方法 先给出 sub_module module sub(input [7:0] din,output logic [7:0] dout…

手撕深度学习中的损失函数(上)

面试中经常会问到损失函数的相关问题,本文推导了深度学习中常用损失函数的计算公式和反向传播公式,并使用numpy实现。 定义损失函数基类: class Loss:def loss(self, predictions, targets):raise NotImplementedErrordef grad(self, predic…

SQL Server数据库-----基础知识

数据库基础数据类型 整数类型 int 范围 2的正负31次方 小数类型 decimal 范围 正负10的38次方,不包含两端的 固定长度的非Unicode字符 char 可变长度的非Unicode字符 varchar 如varchar(20)是最多可以有20个字符,-12-3 可变长度的Unicode字符 nvar…

xmind免费安装使用教程

一、简介 xmind 是一款功能强大的思维导图和脑图制作工具,它可以帮助用户将复杂的信息和想法以图形化的方式进行组织和展示,使得思维更加清晰和有条理。xmind 是一款跨平台的思维导图软件,支持 Windows、MacOS 和 Linux 系统。它提供了丰富的…

pytorch进阶学习(八):使用训练好的神经网络模型进行图片预测

课程资源: 【小学生都会的Pytorch】九、运用你的模型做预测(1)_哔哩哔哩_bilibili 笔记: pytorch进阶学习(四):使用不同分类模型进行数据训练(alexnet、resnet、vgg等&#xff09…

免费远程桌面连接工具合集

随着科技的进步和通信技术的发展,远程办公变得越来越普遍。这种办公模式有助于提高工作效率,对于员工来说很友好的是,上班变得更加灵活了。 今天就给大家推荐几款远程桌面连接工具,不仅可以电脑连接,手机也可以直接连…

读写分离导致读不到刚插入的数据

背景 前两天在做一个功能的时候,需要先插表,如果数据重复则从数据库中查询出这条数据,这段代码在测试环境并没有什么问题,但是到生产之后就会偶现的报一些错,就是读不到已插入的数据,导致后续业务出现问题…