从0到1学习node.js(express模块)
文章目录
- Express框架
- 1、初体验express
- 2、什么是路由
- 3、路由的使用
- 3、获取请求参数
- 4、电商项目商品详情场景配置路由占位符规则
- 5、小练习,根据id参数返回对应歌手信息
- 6、express和原生http模块设置响应体的一些方法
- 7、其他响应设置
- 8、express中间件
- 8.1、什么是中间件
- 8.2、中间件的作用
- 8.3、中间件的类型
- 8.4、定义全局中间件
- 8.5、定义路由中间件
- 8.6、静态资源中间件
- 9、获取请求体数据
- 10、防盗链的实现
- 11、路由的模块化
Express框架
1、初体验express
// 导入express包
const express = require('express')// 创建应用对象
const app = express()// 创建路由
app.get('/home', (req, res) => {res.end('hello express')
})// 启动服务监听端口
app.listen(3000, ()=>{console.log('服务启动成功。。。')
})
2、什么是路由
官方定义:路由确定了应用程序如何响应客户端对特定端点的请求
3、路由的使用
// 导入express包
const express = require('express')// 创建应用对象
const app = express()// 创建路由
app.get('/home', (req, res) => {res.end('hello express')
})// 创建路由
app.post('/login', (req, res) => {res.end('login')
})// 匹配全部
app.all('/all', (req, res) => {res.end('all')
})// 全都匹配不上就走这里
app.all('*', (req, res) => {res.end('Not Found 404')
})// 启动服务监听端口
app.listen(3000, ()=>{console.log('服务启动成功。。。')
})
3、获取请求参数
const express = require('express')// 创建应用对象
const app = express()app.get('/request', (req, res) => {// http模块方法console.log('原生获取url ', req.url)console.log('原生获取请求方式 ', req.method)console.log('原生获取http版本号 ',req.httpVersion)console.log('原生获取headers ',req.headers)// express 封装的方法console.log('express获取url ', req.path)console.log('express获取请求参数 ',req.query);// 获取ip地址console.log('express获取ip地址 ', req.ip);// 获取指定headers中的内容console.log('express获取指定header',req.get('host'))res.setHeader('content-type', 'text/html;charset=utf-8')res.end('请求成功!')
})app.listen(3000, () => {console.log('服务启动成功,监听端口3000')
})


4、电商项目商品详情场景配置路由占位符规则
// 导入express模块
const express = require('express')
// 创建应用对象
const app = express()// 创建路由
// :id占位符,所有这种格式的请求都会进入这里
app.get('/:id.html', (req, res) => {// params上存储所有的请求参数,id就是路由中的id,字段名必须一致才能取出来console.log(req.params.id)res.setHeader('content-type', 'text/html;charset=utf-8')res.end('商品详情')
})// 启动服务
app.listen(3000, () => {console.log('服务启动成功,监听端口3000')
})
5、小练习,根据id参数返回对应歌手信息
const express = require('express')const app = express()const singers = [{name: '周杰伦',id: 1},{name: '许嵩',id: 2},{name: '汪苏泷',id: 3}
]
// 根据id返回指定数据
app.get('/:id.html', (req, res) => {const data = singers.filter(item => item.id == req.params.id)console.log(data)if (data.length == 0) {res.statusCode = 404res.end('<h1>404 Not Found</h1>')return}res.setHeader('content-type', 'text/html;charset=utf-8')res.end(JSON.stringify(data[0]))
})app.listen(3000, () => {console.log('服务启动成功')
})
6、express和原生http模块设置响应体的一些方法
const express = require('express')const app = express()app.get('/response', (req, res) => {// 原生方法// 修改状态码res.statusCode = 404res.statusMessage = 'abcd'// 设置响应头res.setHeader('111', '222')// 设置响应体res.write('hello express')res.end('response')// express 方法res.status(500)res.set('aaa','bbb')res.send('你好 我是send') // 使用send会自动配置响应头Content-Type:text/html; charset=utf-8,中文不乱码res.status(500).set('aaa','bbb').send('你好 我是send') // 可以链式调用
})app.listen(3000, () => {console.log('服务启动成功')
})
7、其他响应设置
const express = require('express')const app = express()app.get('/other', (req, res) => {// 重定向res.redirect('http://www.baidu.com')// 下载res.download(__dirname + '/index.js')// JSON响应res.json({name:'你好'})// 响应文件内容res.sendFile(__dirname + './text.html')
})app.listen(3000, () => {console.log('服务启动成功')
})
8、express中间件
8.1、什么是中间件
中间件本质是一个回调函数
中间件函数可以像路由回调一样访问请求对象(request),响应对象(response)
8.2、中间件的作用
中间件的作用就是使用函数封装公共操作,简化代码
8.3、中间件的类型
- 全局中间件
- 路由中间件
8.4、定义全局中间件
// 导入
const express = require('express')
const fs = require('fs')
const path = require('path')const app = express()// 声明中间件函数,共有三个参数,请求报文。响应报文。和next函数
// next()函数如果后续有代码执行,必须调用。
function recordMiddleware(req, res, next) {// 获取url和IP地址let { url, ip } = reqfs.appendFileSync(path.resolve(__dirname, './access.log'), `ip${ip}访问了${url}\r\n`)next()
}// 使用中间件函数
app.use(recordMiddleware)app.get('/home', (req, res) => {res.send('前台首页')
})app.get('/admin', (req, res) => {res.send('后台首页')
})app.all('*', (req, res) => {res.send('<h1>404 Not Found</h1>')
})app.listen(3000, () => {console.log('服务启动成功')
})
8.5、定义路由中间件
const express = require('express')// 创建应用对象
const app = express()// 定义全局路由中间价函数
const checkCodeMiddleware = (req, res, next) => {let { code } = req.queryif (code != '521') {res.send('暗号错误!')return}next()
}// 可以全局注册也可以局部使用,直接在路由中调用
app.get('/home', checkCodeMiddleware, (req, res) => {res.send('前台页面')
})app.get('/admin', (req, res) => {res.send('后台页面')
})app.listen(3000, () => {console.log('服务启动成功...')
})
8.6、静态资源中间件
// 静态资源中间件设置, public就是静态资源目录。配置以后不管任何文件格式,这个方法都会给我们配置好mime类型。
app.use(express.static(__dirname + '/public'))
9、获取请求体数据
要使用到一个中间件body-parser,这个中间件有两个方法
先安装中间件npm i body-parser
const bodyParser = require('body-parser')
// 解析JSON格式的请求体的中间件
const jsonParser = bodyParser.json()
// 解析 querystring 格式请求体的中间件
const urlencodedParser = bodyParser.urlencoded({extended:false})app.post('/login', urlencodedParser, (req,res)=>{// 调用这个中间件以后,会给req中添加一个body,就是请求参数const {username} = req.bodyres.send(username)
})
10、防盗链的实现
防盗链就是指一个网站的一些静态资源,通过判断请求头中的referer属性是否为本服务ip或者域名,从而阻止一些外部系统访问资源。
const express = require('express')const app = express()// 静态资源中间价设置
app.use(express.static(__dirname + '/public'))// 防盗链的原理主要是判断请求头中的referer 是否为自己服务的地址
const staticMiddleware = (req, res, next) => {// 检测请求头中的referer是否为 127.0.0.1// 获取refererlet referer = req.get('referer')if (referer) {// 序列化refererlet url = new URL(referer)let hostname = url.hostnameconsole.log(hostname)if (hostname !== '127.0.0.1') {// 响应404res.status(404).send('<h1>404 Not Found</h1>')}}next()
}app.use(staticMiddleware)app.get('/login', (req, res) => {res.send('登录')
})app.listen(3000, () => {console.log('服务启动成功...')
})
11、路由的模块化
创建一个routers目录。创建homeRouters.js文件存放路由
const express = require('express')
// 创建路由对象
const router = express.Router()router.get('/admin', (req, res) => {res.send('后台管理')
})// 暴露router
module.exports = router
主要文件引入routers里面的文件,使用app.use挂载到app上
const express = require('express')
const homeRouters = require('./routers/home.js')
const adminRouters = require('./routers/admin.js')const app = express()app.use(homeRouters)
app.use(adminRouters)app.all('*', (req, res) => {res.send('<h1>404 Not Found</h1>')
})app.listen(3000, () => {console.log('服务启动成功...')
})
全部文章
从0到1学习node.js(fs模块)
从0到1学习node.js(path模块以及HTTP协议)
从0到1学习node.js(http模块)
从0到1学习node.js(npm)
相关文章:
从0到1学习node.js(express模块)
文章目录 Express框架1、初体验express2、什么是路由3、路由的使用3、获取请求参数4、电商项目商品详情场景配置路由占位符规则5、小练习,根据id参数返回对应歌手信息6、express和原生http模块设置响应体的一些方法7、其他响应设置8、express中间件8.1、什么是中间件…...
MambaVision
核心速览 研究背景 研究问题 :这篇文章提出了一种新的混合Mamba-Transformer骨干网络,称为MambaVision,专为视 觉应用量身定制。研究的核心问题是如何有效地结合Mamba的状态空间模型(SSM)和Transf ormer的自注意力机制…...
MySQLDBA修炼之道-开发篇(二)
四、开发进阶 1. 范式和反范式 范式是数据库规范化的一个手段,是数据库设计中的一系列原理和技术,用于减少数据库中的数据冗余,并增进数据的一致性。 范式 1.1 第一范式 第一范式是指数据库表的每一列(属性)都是不可…...
前端必备的环境搭建
一、nvm安装详细教程(安装nvm、node、npm、cnpm、yarn及环境变量配置) 参考地址:nvm安装详细教程(安装nvm、node、npm、cnpm、yarn及环境变量配置)-CSDN博客 说明: 1)关于nodejs目录不显示&a…...
SpringCloud笔记
什么是降级熔断?为什么要进行熔断? 熔断降级是一种分布式系统的保护机制,用于应对服务不稳定或不可用的情况。 熔断是指当某个服务的调用失败次数或异常比例达到一定阈值时,自动切断对该服务的调用,让请求快速失败&…...
优秀的程序员思考数据结构
原文地址:https://read.engineerscodex.com/p/good-programmers-worry-about-data 我最近在这篇很棒的 Stack Overflow 文章中看到了 Linus Torvalds(Linux 和 Git 的创建者)的一句话。(这篇文章回顾了那篇文章中的许多引述。 它…...
「C/C++」C/C++标准库之#include<cstdlib>通用工具库
✨博客主页何曾参静谧的博客📌文章专栏「C/C」C/C程序设计📚全部专栏「VS」Visual Studio「C/C」C/C程序设计「UG/NX」BlockUI集合「Win」Windows程序设计「DSA」数据结构与算法「UG/NX」NX二次开发「QT」QT5程序设计「File」数据文件格式「PK」Parasoli…...
Oracle视频基础1.1.3练习
1.1.3 需求: 完整格式查看所有用户进程里的oracle后台进程 查看物理网卡,虚拟网卡的ip地址 ps -ef | grep oracle /sbin/ifconfig要以完整格式查看所有用户进程中的 Oracle 后台进程,并查看物理和虚拟网卡的 IP 地址,可以使用以下…...
python项目实战——多协程下载美女图片
协程 文章目录 协程协程的优劣势什么是IO密集型任务特点示例与 CPU 密集型任务的对比处理 I/O 密集型任务的方式总结 创建并使用协程asyncio模块 创建协程函数运行协程函数asyncio.run(main())aiohttp模块调用aiohttp模块步骤 aiofiles————协程异步函数遇到的问题一 await …...
基于.NET 8.0,C#中Microsoft.Office.Interop.Excel来操作office365的excel
开发环境: Visual Studio 2022 office365 项目模板:WPF应用程序 框架:.NET 8.0 依赖:Microsoft.Office.Interop.Excel 注意: 1.使用Microsoft.Office.Interop.Excel库时,服务器或电脑里面必须安装得…...
使用无线方式连接Android设备进行调试的两种方法
1.使用配对码配对设备方式 手机(或者平板等安卓设备)和电脑需连接在同一WiFi 下;保证 SDK 为最新版本(adb --version ≥ 30.0.0); step1.手机启用开发者选项和无线调试模式(会提示确认ÿ…...
Valgrind的使用
Valgrind 是一个强大的开源工具,用于检测程序中的内存错误、内存泄漏以及线程问题。它广泛应用于 C/C++ 等需要手动管理内存的编程语言中。以下内容将详细介绍 Valgrind 的安装、基本使用方法、常用命令及其输出结果的解析。 1. 什么是 Valgrind? Valgrind 是一个用于内存调…...
微信小程序瀑布流实现,瀑布流长度不均等解决方法
这是一开始实现的瀑布流,将数据分为奇数列和偶数列 <view class"content-left"><block wx:for"{{list}}" wx:key"list"><template isitem-data data{{...item}} wx:if"{{index % 2 0}}"></template&…...
Notepad++通过自定义语言实现日志按照不同级别高亮
借助Notepad的自定义语言可以实现日志的按照不同级别的高亮; 参考: https://blog.csdn.net/commshare/article/details/131208656 在此基础上做了一点修改效果如下: xml文件: <NotepadPlus><UserLang name"Ansibl…...
2024年四川省大学生程序设计竞赛 补题记录
文章目录 Problem A. 逆序对染色(思维树状数组)Problem B. 连接召唤(贪心)Problem E. L 型覆盖检查器(模拟)Problem F. 小球进洞:平面版(几何)Problem G. 函数查询Proble…...
17_事件的处理
目录 绑定事件与解绑事件优化事件的绑定和解绑方式处理不同事件类型的绑定处理同一事件类型多个事件处理函数事件冒泡与更新时机问题 绑定事件与解绑事件 既然要处理事件,那么首先面临的问题是如何在 vnode 中描述这个事件,在 vnode.props 中࿰…...
1FreeRTOS学习(队列、二值信号量、计数型信号量之间的相同点和不同点)
相同点: (1)传递区间 队列、二值信号量、计数型信号量均可用在任务与任务,任务与中断之间进行消息传递 (2) 传递方式 创建队列--发送队列--接受队列 创建二值信号量--发送二值信号量--接受二值信号量 创建计…...
数据库设计与范式及其应用
数据库设计是数据库管理系统(DBMS)中的核心环节,良好的数据库设计不仅可以提高数据存取的效率,还能增强数据的可维护性和一致性。范式(Normalization)是一种设计原则,用于减少数据冗余和提高数据…...
笔记-配置PyTorch(CUDA 12.2)
文章目录 前言一、安装 PyTorch(CUDA 12.2)1. 创建并激活 Conda 环境2. 安装 PyTorch(CUDA 12.2)3. 安装 torch_geometric 及依赖项4. 验证安装 总结 前言 一、安装 PyTorch(CUDA 12.2) 1. 创建并激活 Con…...
[C++]——红黑树(附源码)
目录 一、前言 二、正文 2.1 红黑树的概念 2.2 红黑树的性质 2.3红黑树节点的定义 2.4 红黑树的插入 2.4.1 情况一 2.4.2 情况二 编辑 2.4.3 情况三 2.5 红黑树的验证 三、全部代码 四、结语 一、前言 在上一篇博客中,为小伙伴们进行了AVL树的讲解&#…...
7.4.分块查找
一.分块查找的算法思想: 1.实例: 以上述图片的顺序表为例, 该顺序表的数据元素从整体来看是乱序的,但如果把这些数据元素分成一块一块的小区间, 第一个区间[0,1]索引上的数据元素都是小于等于10的, 第二…...
应用升级/灾备测试时使用guarantee 闪回点迅速回退
1.场景 应用要升级,当升级失败时,数据库回退到升级前. 要测试系统,测试完成后,数据库要回退到测试前。 相对于RMAN恢复需要很长时间, 数据库闪回只需要几分钟。 2.技术实现 数据库设置 2个db_recovery参数 创建guarantee闪回点,不需要开启数据库闪回。…...
利用ngx_stream_return_module构建简易 TCP/UDP 响应网关
一、模块概述 ngx_stream_return_module 提供了一个极简的指令: return <value>;在收到客户端连接后,立即将 <value> 写回并关闭连接。<value> 支持内嵌文本和内置变量(如 $time_iso8601、$remote_addr 等)&a…...
《Playwright:微软的自动化测试工具详解》
Playwright 简介:声明内容来自网络,将内容拼接整理出来的文档 Playwright 是微软开发的自动化测试工具,支持 Chrome、Firefox、Safari 等主流浏览器,提供多语言 API(Python、JavaScript、Java、.NET)。它的特点包括&a…...
解锁数据库简洁之道:FastAPI与SQLModel实战指南
在构建现代Web应用程序时,与数据库的交互无疑是核心环节。虽然传统的数据库操作方式(如直接编写SQL语句与psycopg2交互)赋予了我们精细的控制权,但在面对日益复杂的业务逻辑和快速迭代的需求时,这种方式的开发效率和可…...
P3 QT项目----记事本(3.8)
3.8 记事本项目总结 项目源码 1.main.cpp #include "widget.h" #include <QApplication> int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); } 2.widget.cpp #include "widget.h" #include &q…...
土地利用/土地覆盖遥感解译与基于CLUE模型未来变化情景预测;从基础到高级,涵盖ArcGIS数据处理、ENVI遥感解译与CLUE模型情景模拟等
🔍 土地利用/土地覆盖数据是生态、环境和气象等诸多领域模型的关键输入参数。通过遥感影像解译技术,可以精准获取历史或当前任何一个区域的土地利用/土地覆盖情况。这些数据不仅能够用于评估区域生态环境的变化趋势,还能有效评价重大生态工程…...
GruntJS-前端自动化任务运行器从入门到实战
Grunt 完全指南:从入门到实战 一、Grunt 是什么? Grunt是一个基于 Node.js 的前端自动化任务运行器,主要用于自动化执行项目开发中重复性高的任务,例如文件压缩、代码编译、语法检查、单元测试、文件合并等。通过配置简洁的任务…...
C# 表达式和运算符(求值顺序)
求值顺序 表达式可以由许多嵌套的子表达式构成。子表达式的求值顺序可以使表达式的最终值发生 变化。 例如,已知表达式3*52,依照子表达式的求值顺序,有两种可能的结果,如图9-3所示。 如果乘法先执行,结果是17。如果5…...
CVPR2025重磅突破:AnomalyAny框架实现单样本生成逼真异常数据,破解视觉检测瓶颈!
本文介绍了一种名为AnomalyAny的创新框架,该方法利用Stable Diffusion的强大生成能力,仅需单个正常样本和文本描述,即可生成逼真且多样化的异常样本,有效解决了视觉异常检测中异常样本稀缺的难题,为工业质检、医疗影像…...
