【Node.js】Express框架的基本使用

 

✍️ 作者简介: 前端新手学习中。
💂 作者主页: 作者主页查看更多前端教学
🎓 专栏分享:css重难点教学       Node.js教学 从头开始学习

目录

 

初识Express

        Express简介

                什么是Express

                进一步理解 Express

                Express能做什么

         Express的基本使用

                安装

                创建基本的Web服务器

                监听GET请求

                监听post请求

                 获取URL中携带的查询参数

                获取URL中的动态参数

初始Express

        托管静态资源

                express.static()

                挂载路径前缀

         nodemon

                为什么要使用nodemon

                安装 nodemon 

                使用nodemon

Express 路由

        路由的概念

                什么是路由

                现实生活中的路由

                 Express中的路由

                 路由的匹配过程

         路由的使用

                最简单的用法

                 模块化路由

                创建路由模块 

 Express中间件

        中间件的概念

                什么是中间件

                现实生活中的例子

                 Express中间件的调用流程

                Express中间件的格式 

                next函数的作用

        Express中间件的初体验

                定义中间件函数

                       触发使用中间件函数


初识Express

        Express简介

                什么是Express

官方给出的概念:Express是基于Node.js平台,快捷,开放,极简的Web开发框架

 通俗的理解,Express的作用和Node.js内置的http模块类似,是专门用来创建Web服务器的。

Express的本质:就是一个npm上的第三包,提供了快速创建Web服务器的便捷方法。

Express的中文官网:express官网

                进一步理解 Express

Express的开发效率更高,http内置模块用起来很复杂,开发效率低,Express是基于内置的http模块进一步封装出来的。能够极大地提高开发效率。

http内置模块与Express类似于WebAPI和jquery的关系,后者是基于前者进一步封装出来的

                Express能做什么

对于前端程序员来说,最常见的两种服务器,分别是:

  • Web网站服务器:专门对外提供Web网页资源的服务器。
  • API接口服务器:专门对外提供API接口的服务器。

使用Express,我们可以方便,快捷的创建Web网站的服务器或API接口的服务器。

         Express的基本使用

                安装

在项目所处的根目录中,运行如下的终端命令,就可以安装express到项目中使用。

npm i express@4.17.1

 尽量安装指定版本 避免后面有什么不一样的 出错

                创建基本的Web服务器

使用npm下载完第三方包之后,使用expres创建服务器

//导入express
const express = require('express');
//创建Web服务器
const app = express();
//监听服务器
app.listen(8080, () => {
    console.log('服务器创建成功');
})

                监听GET请求

通过app.get(),方法监听客户端的GET请求。

//监听get请求
app.get('/user', (req, res) => {
    //res.sen方法向客户端响应数据
    res.send({
        name: 'xiaoxie',
        age: 20,
        gender: '男'
    })
})

 启动服务器  在postCode中输入地址发送get请求,拿到数据。

                监听post请求

通过app.post()方法,可以监听客户端的post请求。

app.post('/user', (req, res) => {
    res.send('请求成功')
})

                 获取URL中携带的查询参数

通过req.query对象,可以访问到客户端通过查询字符串的形式,发送到服务器的参数:

就是将ajax中通过serialize()方法得到的键值对字符串 转换成对象。

app.get('/', (req, res) => {
    //默认情况下 是一个空对象
    console.log(req.query);
    res.send(req.query);
})

在地址栏问号后面写,跟再params里写是一样的。

                获取URL中的动态参数

通过req.params对象,可以访问到URL中,通过:匹配动态参数,冒号是固定写法表示后面是动态参数,显示名称id可以自定义任何名称。

app.get('/user/:id/:name', (req, res) => {
    //默认情况下 是一个空对象
    console.log(req.params);
    res.send(req.params);
})

初始Express

        托管静态资源

                express.static()

express提供了一个非常好用的函数,叫做express.static(),通过它,我们可以非常方便地创建一个静态资源管理器,例如,通过以下代码就可以将public目录下的图片,CSS文件,JavaScript文件,对外开放访问了。

我们将前面的时钟案例,clock文件夹对外开放。

// 将clock目录对外开放

//导入express

const express = require('express');
//实例化
const app = express();
//使用express.static()方法,快速对外提供静态资源
app.use(express.static('./时钟/clock'))


//监听
app.listen(8080, () => {
    console.log('访问成功 地址为http://127.0.0.1:8080');
})

直接在路径栏里进行访问,访问的时候文件夹需要省略,直接写文件名即可。

 如果挂载多个文件夹,且有相同的文件名,咋按从上到下书写的先后顺序来显示 第一个文件。

                挂载路径前缀

我们可以在地址栏访问指定文件前,可以加上伪装的文件夹名。

这个abc 并不是真实存在的文件夹,只是在地址栏访问时,必须需要加上这个前缀名。

app.use('abc', express.static('./时钟/clock'))

         nodemon

                为什么要使用nodemon

 在编写测试Node.js项目的时候,如果修改了项目的代码,则需要频繁的手动close掉,然后重复启动,非常繁琐,现在,我们可以使用nodemon这个工具,他能够监听项目文件的变动,当代码被修改后,nodemon会自动帮我们重启项目,极大方便了开发和测试。

                安装 nodemon 

全局安装nodemon。

npm i nodemon -g 

                使用nodemon

nodemon 文件名

运行之后,只要修改文件保存后,就会自动重启项目。

Express 路由

        路由的概念

                什么是路由

广义上来讲,路由就是映射关系。

                现实生活中的路由

                 Express中的路由

在Express中,路由指的是客户端的请求与服务器处理函数之间的映射关系。

Express中的路由分3部分组成,分别是请求的类型,请求的URL地址,处理函数。

 

                 路由的匹配过程

每当一个请求到达服务器之后,需要先经过路由的匹配,只有匹配成功之后,才会调用对应的处理函数。

在匹配时,会按照路由的顺序进行匹配,如果请求类型和请求的URL同时匹配成功,则Express会将这次请求,转交给对应的function函数进行处理。

 

         路由的使用

                最简单的用法

在Express中使用路由器最简单的方式,就是把路由挂载到app上。

const express = require('express');
const app = express();

app.get('/', (req, res) => {
    res.send('hello world')
})

app.post('/', (req, res) => {
    res.send('hello post')
})

app.listen(8080, () => {
    console.log('http:127.0.0.1:8080');
})

                 模块化路由

为了方便对路由进行模块化的管理,EXpress不建议将路由直接挂载到app上,而是推荐将路由抽离为单独的模块。

将路由抽离为单独模块的步骤如下:

  1. 创建路由模块对应的js文件
  2. 调用express.Router()函数创建路由对象
  3. 向路由对象上挂载具体的路由
  4. 使用module.exports向外共享路由对象
  5. 使用app.use()函数注册路由模块

                创建路由模块 

在一个新js文件里创建路由模块并向外暴露。

//这是路由模块


//导入express
const express = require('express');
//创建路由对象
const router = express.Router();

//挂载具体的路由

router.get('/user/list', (req, res) => {
    res.send('Get user list')
})

router.post('/user/add', (req, res) => {
    res.send('Add new user');
})

//向外曝光路由对象
module.exports = router;

导入并注册路由模块。

const express = require('express');
const app = express();

//导入路由模块
const router = require('./route.js')
//注册路由模块
app.use(router);

app.listen(8080, () => {
    console.log('http:127.0.0.1:8080');
})

 注意 app.use的作用就是用来注册全局中间件

                为路由模块添加访问前缀

const express = require('express');
const app = express();

//导入路由模块
const router = require('./route.js')
//注册路由模块
//添加前缀
app.use('/api', router);

app.listen(8080, () => {
    console.log('http:127.0.0.1:8080');
})

 Express中间件

        中间件的概念

                什么是中间件

中间件,特指业务流程的中间处理环节。

                现实生活中的例子

在处理污水的时候,一般都要经过三个处理环节,从而保证处理过后的废水,达到排放标准。

                 Express中间件的调用流程

 当一个请求到达Express的服务器之后,可以连续调用多个中间件,从而对这次请求进行预处理。

 

                Express中间件的格式 

                 Express的中间件,本质上就是一个function处理函数,Express中间件的格式如下:

 

 注意:中间件函数的形参列表中,必须包含next参数。而路由处理函数中只包含req和res。

                next函数的作用

 next函数是实现多个中间件连续调用的关键,它表示把流转关系转交给下一个中间件或路由。

        Express中间件的初体验

                定义中间件函数

可以通过如下的方式,定义一个最简单的中间件函数

const express = require('express');

const app = express();

//定义一个简单的中间件函数

const mw = function (req, res, next) {
    console.log('这是最简单的中间件函数');
    //把流转关系转交给下一个中间件
    next()
}


app.listen(8080, () => {
    console.log('http://localhost:8080');
})

                       触发使用中间件函数

客户端发起的任何需求,到达服务器之后,都会触发的中间件,叫做全局生效的中间件。

通过调用app.use(中间件函数),即可定义一个全局生效的中间件。

  

//定义一个简单的中间件函数

const mw = function (req, res, next) {
    console.log('这是最简单的中间件函数');
    //把流转关系转交给下一个中间件
    next()
}

//全局生效的中间件
app.use(mw)

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

分享:如何给 DBA 减负?

欢迎访问 OceanBase 官网获取更多信息:https://www.oceanbase.com/ 本文来自OceanBase社区分享,仅限交流探讨。原作者肖杨,OceanBase 软件开发工程师。 研发、数据分析师及运维内部人员有数据查询、数据订正等需求,若无管控平台&…

Midjourney 使用总结

1.关键词提问 中国古典女性,东方美女极致面容站在运河码头遥望丈夫,史诗奇幻场景风格,深绿浅棕,细节风帆,柔焦,人像隐喻,4K,电影级高品质照片,全景图, 焦距 …

突破市场壁垒:如何利用关键词采集和市场调查找到你的细分市场?

在市场竞争日益激烈的今天,寻找一个适合自己的细分市场成为了每个企业和创业者的必要之举。然而,许多人在寻找细分市场时陷入了困境,不知道如何找到一个符合自己产品的市场,因此,在这种情况下,利用关键词采…

UVM response_handler和get_response机制

很多UVM用户平时更多的使用get_response()方式去获得uvm_driver的response,但get_response有些缺点:由于 get_response() 是一种阻塞方法,它会阻塞直到收到来自 UVM 驱动程序 (put_response()) 的响应。因此,如果我们使用 get_res…

CleanMyMac X4.20最新mac电脑优化工具好用吗?

如果你的Mac运行速度变慢,很有可能是因为RAM内存被过度占用了。本文将向Mac用户,尤其是小白用户归纳一些常见的Mac内存清理方法。通过释放RAM内存,你将会看到自己Mac的运行速度有显著提升。 你的Mac运行速度是否变得慢到让人抓狂?…

项目下载中心-超简单版解决方案

简单的下载中心的设计流程 直接上设计流程: 以上就是步骤了,至于每个步骤怎么实现,那方法就很多了 ,随意,达到目的就行。 至于各种问题,比如队列性能,消息重复或丢失,等等&#…

130亿参数,8个A100训练,UC伯克利发布对话模型Koala

平替再平替,可以在消费级 GPU 上运行的 Koala 模型能实现 ChatGPT 一半的性能。 自从 Meta 发布并开源了 LLaMA 系列模型,来自斯坦福大学、UC 伯克利等机构的研究者们纷纷在 LLaMA 的基础上进行「二创」,先后推出了 Alpaca、Vicuna 等多个「…

Solon v2.2.7 发布,支持 Java 20

Solon 是一个高效的 Java 应用开发框架:更快、更小、更简单。也是一个有自己接口标准规范的开放生态。 150来个生态插件,覆盖各种不同的应用开发场景: 相对于 Spring Boot 和 Spring Cloud 的项目: 启动快 5 ~ 10 倍…

【无功优化】基于改进遗传算法的电力系统无功优化研究【IEEE30节点】(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

4.5--计算机网络之基础篇--1.模型分层--(复习+深入)---好好沉淀,加油呀

1.TCP/IP模型的分层 1.1.为什么要有 TCP/IP 网络模型? 对于同一台设备上的进程间通信,有很多种方式,比如有管道、消息队列、共享内存、信号等方式; 而对于不同设备上的进程间通信,就需要网络通信,而设备是…

2021蓝桥杯真题大写 C语言/C++

题目描述 给定一个只包含大写字母和小写字母的字符串,请将其中所有的小写字母转换成大写字母后将字符串输出。 输入描述 输入一行包含一个字符串。 输出描述 输出转换成大写后的字符串。 输入输出样例 示例 输入 LanQiao 输出 LANQIAO 评测用例规模与约定 对于…

python 生成器、迭代器、动态新增属性及方法

目录 一、生成器 1、生成器定义 2、生成器存在的意义 3、创建生成器方式一(生成器表达式) 4. 创建生成器方式二(生成器函数) 1. 生成器函数 2. 生成器函数的工作原理 5. 总结 1. 什么是生成器 2. 生成器特点 二、迭代器…

365天深度学习训练营-第J8周:Inception v1算法实战与解析

目录 一、前言 二、论文解读 1. Inception 模块 2. 网络深度问题 3. 全局平均池化 4. 卷积层的并行结构 5. 1x1 卷积核 6.详细的网络结构 三、代码复现 一、前言 🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者&#x…

微服务+springcloud+springcloud alibaba学习笔记【Eureka服务注册中心】(3/9)

Eureka服务注册中心 3/91、服务注册与发现1.1 什么是服务治理:1.2 什么是服务注册与发现:1.3 Eureka服务注册与发现2、单机版eureka2.1 创建module2.2改pom依赖2.3写yml配置文件:2.4主启动类2.5 修改服务提供者 cloud-provider-payment8001 模块&#xf…

Github库中的Languages显示与修改

目录 前言 【.gitattributes】文件 修改GitHub语言 前言 上传一个项目到GitHub时,发现显示的语言并非是自己项目所示的语言,这样的情况是经常发生的,为了能到达自己所需快速检索,或者是外部访问者能很好的搜索我们的项目&#…

Sentinel滑动时间窗限流算法原理及源码解析(中)

文章目录 MetricBucketMetricEvent数据统计的维度WindowWrap样本窗口实例 范型T为MetricBucket windowLengthInMs 样本窗口长度 windowStart 样本窗口的起始时间戳 value 当前样本窗口的统计数据 其类型为MetricBucket MetricBucket MetricEvent数据统计的维度 1、首先计算27t位…

【花雕学AI】09:发挥ChatGPT最大潜力——产生高质量内容的九种方法和建议

人工智能(AI)是当今科技领域最热门和最有前景的话题之一,它已经渗透到了我们生活和工作的方方面面,给我们带来了许多便利和惊喜。而在AI的众多分支中,自然语言处理(NLP)是最贴近人类的一个领域&…

6-python异常、错误、模块、包

文章目录1.异常2.错误3.模块4.包[综合练习]1.异常 打开一个不存在的文件会引发异常 FileNotFoundError: [Errno 2] No such file or directory: ‘D:/不存在的文件.txt’ fopen(file"D:/不存在的文件.txt",mode"r", encodingutf-8) print(f.read())&…

springboot-gateway注册nacos失败,控制台没有报错

目录 前言现象描述前言 最近springboot的gateway注册到nacos上,没有注册成功 现象描述 我是在common里面引入了nacos的依赖,依赖如下: <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-confi…

文件的随机读写

fseek fseek这个函数的作用是什么&#xff1f; 我们知道&#xff0c;如果对一个文件指针进行加减操作的话&#xff0c;这个文件指针会指向下一个文件&#xff0c;那么问题来了&#xff0c;我们如果想访问这个文件中的某一个内容&#xff0c;这个时候该怎么办呢&#xff0c;我们…