深入理解nodejs中Express的中间件
发布时间 - 2026-01-11 01:10:50 点击率:次Express是一个基于Node.js平台的web应用开发框架,在Node.js基础之上扩展了web应用开发所需要的基础功能,从而使得我们开发Web应用更加方便、更加快捷。

举一个例子:
用node.js实现一个控制台打印“hello server”
var http = require('http');
var server = http.createServer(function(req,res){
console.log("hello server");
});
server.listen(3000);
这样子的话,当我们需要处理各种请求(主要指GET、POST)时,我们需要将所有请求类型处理的代码写在createServer包裹的函数里。
用Express实现一个控制台打印“hello server”
var express = require('express');
var app = express();
http.createServer(app);
// 处理用户请求(路由)
app.get("/",function(){
console.log("hello server");
})
Express处理各种请求是通过Express执行函数去调用对应的方法,这样是不是更加方便和快捷了。
Express的API文档完整易懂,2010-01-03陆续发布了几个版本,其中第三版和第四版差异比较大, 主要体现在第三版的中间件基本上都是继承了connect框架的,而第四版将中间件独立出来了,不在依赖connect框架。
说到中间件,官网对它的阐述是这样的:
“Express是一个自身功能极简,完全是路由和中间件构成一个web开发框架:从本质上来说,一个Express应用就是在调用各种中间件。”
由此可见,中间件在Express开发中的重要性,因此这里我们就专门来总结一下中间件。
一、中间件结构
1、app.use([path],function)
path:是路由的url,默认参数‘/',意义是路由到这个路径时使用这个中间件
function:中间件函数
这个中间件函数可以理解为就是function(request,response,next)
这里安装是指涉及到第三方中间件的使用时,需要先安装好,然后在使用。
二、中间件分类
1、内置中间件
express.static 是Express目前唯一内置的一个中间件。用来处理静态资源文件。
什么意思了? 来run一下代码看看
// index.js
var express = require('express');
var app = express();
app.use(express.static(__dirname + '/public'));
启动服务: node index.js
浏览器中访问: http://localhost:1234/ 展示的/public/index.html内容
浏览器中访问: http://localhost:1234/hello.html 展示的/public/hello.html内容
2、自定义中间件
在上面中间件结构中,我们知道了,中间件使用时的第二个参数是一个Function,然而,要自定义一个中间件,就是倒腾一番这个Function。
这个function总共有三个参数(req,res,next);
当每个请求到达服务器时,nodejs会为请求创建一个请求对象(request),该请求对象包含客户端提交上来的数据。同时也会创建一个响应对象(response),响应对象主要负责将服务器的数据响应到客户端。而最后一个参数next是一个方法,因为一个应用中可以使用多个中间件,而要想运行下一个中间件,那么上一个中间件必须运行next()。
好了,有了一个大概的了解,下面我定义一些中间件来实现一个路由功能。
var express = require('express');
var app = express();
app.use(function(request,response,next){
if(request.url === '/'){
response.writeHead(200,{"Content-Type":"text/plain"});
response.end("This is home\n");
} else {
next();
}
})
app.use(function(request,response,next){
if(request.url === '/about'){
response.writeHead(200,{"Content-Type":"text/plain"});
response.end("This is about\n");
} else {
next();
}
})
app.use(function(request,response,next){
response.writeHead(404,{"Content-Type":"text/plain"});
response.end("404 not found!\n");
})
app.listen(1234,'localhost');
浏览器中访问: http://localhost:1234/ 展示This is home
浏览器中访问: http://localhost:1234/about 展示This is about
这样看是不是使用中间件很轻松就实现了路由的功能,当然,有关Express的路由可以专门拿出来写写,哈哈。
3、第三方中间件
有关第三方中间件,这里我们分析几个比较重要和常用的,知道这几个的使用,其它的也就会了。
body-parser :解析body中的数据,并将其保存为Request对象的body属性。
cookie-parser :解析客户端cookie中的数据,并将其保存为Request对象的cookie属性
express-session :解析服务端生成的sessionid对应的session数据,并将其保存为Request对象的session属性
query:这个中间件将一个查询字符串从URL转换为JS对象,并将其保存为Request对象的query属性。这个中间件在第四个版本中已经内置了无需安装。
下面来一个例子,功能是:用户可否登录和在服务端保存登录态。
var express = require('express');
// 引入模板引擎
var hbs = require('express-handlebars');
var bodyParser = require('body-parser');
var session = require('express-session');
var app = express();
// hbs是一个模板引擎
app.engine('hbs',hbs());
app.set('view engine','hbs');
app.set('views','templates');
// 数据库读出来的数据
var userArr = ['wpzheng'];
app.use(session({secret:'maizidu'}));
app.use(bodyParser.urlencoded({extended:true}));
app.get('/', function(request,response,next){
var username = request.session.username;
if(username){
response.send("hello" + username);
}else{
response.render('form');
}
});
app.post('/', function(request,response){
if(userArr.indexOf(request.body.username)>=0){
request.session.username = request.body.username;
}else{
request.session.destroy();
}
// response对象的一个方法 重定向作用
response.redirect('/');
});
app.listen(1234,'localhost');
如果session没有保存数据(测试时可以将服务关闭,session就没有值了,每次向服务器发送请求时,服务会创建一个新的session),就会自动跳到登录页面。当已登录过(也就是说有session值),就直接显示username。
这个例子涉及到模板(hbs)和response的方法(redirect)可以先不管。
三、中间件理解
写到最后了,回到最开始的问题,你是否理解了什么是Express中间件?
结合上面讲解时给出的例子,我们先来分析一下从浏览器地址栏输入url到客户端显示数据之间这个过程到底发生了什么。
浏览器向服务器发送一个请求后,服务器直接通过request.定位属性的方式得到通过request携带过去的数据(有用户输入的数据和浏览器本身的数据信息)。这中间就一定有一个函数将这些数据分类做了处理,已经处理好了,最后让request对象调用使用,对的,这个处理数据处理函数就是我们要说的 中间件 。由此可见,中间件可以总结以下几点:
1、封装了一些处理一个完整事件的功能函数。
2、非内置的中间件需要通过安装后,require到文件就可以运行。
3、封装了一些或许复杂但肯定是通用的功能。
以上所有代码下载:https://github.com/wenpingzheng/express-js.git
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# express的中间件
# express
# 中间件
# nodejs
# express中间件
# Nodejs之Express中间件的分类介绍
# 前端需知nodejs express中间件使用及定义详解
# nodejs express实现中间件
# NodeJs Express中间件超详细讲解
# Nodejs中Express 常用中间件 body-parser 实现解析
# nodejs开发——express路由与中间件
# NodeJs Express中间件使用流程解析
# 是一个
# 保存为
# 客户端
# 器中
# 几个
# 创建一个
# 好了
# 并将其
# 自定义
# 涉及到
# 装了
# 服务端
# 第三版
# 都是
# 第四版
# 就会
# 也会
# 也就
# 多个
# 是这样
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
如何在IIS中配置站点IP、端口及主机头?
如何正确下载安装西数主机建站助手?
Laravel如何使用withoutEvents方法临时禁用模型事件
免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?
简历没回改:利用AI润色让你的文字更专业
Laravel如何集成第三方登录_Laravel Socialite实现微信QQ微博登录
如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环
EditPlus中的正则表达式 实战(1)
怎么用AI帮你设计一套个性化的手机App图标?
HTML透明颜色代码在Angular里怎么设置_Angular透明颜色使用指南【详解】
如何用已有域名快速搭建网站?
Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
高端建站如何打造兼具美学与转化的品牌官网?
文字头像制作网站推荐软件,醒图能自动配文字吗?
如何在建站宝盒中设置产品搜索功能?
MySQL查询结果复制到新表的方法(更新、插入)
Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理
Android GridView 滑动条设置一直显示状态(推荐)
JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)
Laravel怎么实现验证码功能_Laravel集成验证码库防止机器人注册
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
Laravel如何保护应用免受CSRF攻击?(原理和示例)
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
INTERNET浏览器怎样恢复关闭标签页_INTERNET浏览器标签恢复快捷键与方法【指南】
如何在服务器上配置二级域名建站?
Laravel Eloquent模型如何创建_Laravel ORM基础之Model创建与使用教程
网站制作免费,什么网站能看正片电影?
Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)
香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧
音响网站制作视频教程,隆霸音响官方网站?
如何快速启动建站代理加盟业务?
创业网站制作流程,创业网站可靠吗?
Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
Laravel如何升级到最新的版本_Laravel版本升级流程与兼容性处理
Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境
如何在 Pandas 中基于一列条件计算另一列的分组均值
Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程
html5的keygen标签为什么废弃_替代方案说明【解答】
Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧
javascript中对象的定义、使用以及对象和原型链操作小结
教你用AI将一段旋律扩展成一首完整的曲子
laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法
新三国志曹操传主线渭水交兵攻略
Laravel如何实现数据库事务?(DB Facade示例)
Laravel如何使用Telescope进行调试?(安装和使用教程)
Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】
如何快速选择适合个人网站的云服务器配置?

