从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树的讲解&#…...
挑战杯推荐项目
“人工智能”创意赛 - 智能艺术创作助手:借助大模型技术,开发能根据用户输入的主题、风格等要求,生成绘画、音乐、文学作品等多种形式艺术创作灵感或初稿的应用,帮助艺术家和创意爱好者激发创意、提高创作效率。 - 个性化梦境…...
web vue 项目 Docker化部署
Web 项目 Docker 化部署详细教程 目录 Web 项目 Docker 化部署概述Dockerfile 详解 构建阶段生产阶段 构建和运行 Docker 镜像 1. Web 项目 Docker 化部署概述 Docker 化部署的主要步骤分为以下几个阶段: 构建阶段(Build Stage):…...
R语言AI模型部署方案:精准离线运行详解
R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...
Debian系统简介
目录 Debian系统介绍 Debian版本介绍 Debian软件源介绍 软件包管理工具dpkg dpkg核心指令详解 安装软件包 卸载软件包 查询软件包状态 验证软件包完整性 手动处理依赖关系 dpkg vs apt Debian系统介绍 Debian 和 Ubuntu 都是基于 Debian内核 的 Linux 发行版ÿ…...
服务器硬防的应用场景都有哪些?
服务器硬防是指一种通过硬件设备层面的安全措施来防御服务器系统受到网络攻击的方式,避免服务器受到各种恶意攻击和网络威胁,那么,服务器硬防通常都会应用在哪些场景当中呢? 硬防服务器中一般会配备入侵检测系统和预防系统&#x…...
Matlab | matlab常用命令总结
常用命令 一、 基础操作与环境二、 矩阵与数组操作(核心)三、 绘图与可视化四、 编程与控制流五、 符号计算 (Symbolic Math Toolbox)六、 文件与数据 I/O七、 常用函数类别重要提示这是一份 MATLAB 常用命令和功能的总结,涵盖了基础操作、矩阵运算、绘图、编程和文件处理等…...
Python 包管理器 uv 介绍
Python 包管理器 uv 全面介绍 uv 是由 Astral(热门工具 Ruff 的开发者)推出的下一代高性能 Python 包管理器和构建工具,用 Rust 编写。它旨在解决传统工具(如 pip、virtualenv、pip-tools)的性能瓶颈,同时…...
【Linux手册】探秘系统世界:从用户交互到硬件底层的全链路工作之旅
目录 前言 操作系统与驱动程序 是什么,为什么 怎么做 system call 用户操作接口 总结 前言 日常生活中,我们在使用电子设备时,我们所输入执行的每一条指令最终大多都会作用到硬件上,比如下载一款软件最终会下载到硬盘上&am…...
API网关Kong的鉴权与限流:高并发场景下的核心实践
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 引言 在微服务架构中,API网关承担着流量调度、安全防护和协议转换的核心职责。作为云原生时代的代表性网关,Kong凭借其插件化架构…...
在golang中如何将已安装的依赖降级处理,比如:将 go-ansible/v2@v2.2.0 更换为 go-ansible/@v1.1.7
在 Go 项目中降级 go-ansible 从 v2.2.0 到 v1.1.7 具体步骤: 第一步: 修改 go.mod 文件 // 原 v2 版本声明 require github.com/apenella/go-ansible/v2 v2.2.0 替换为: // 改为 v…...
