【随笔】express中间件系统的基本实现

一直觉得express的中间件系统这种流式处理非常形象,就好像加工流水线一样,每个环节都在针对同一个产品的不同部分完成自己的工作,最后得到一个成品。今天就来实现一个简易的【中间件队列】。

一. API层

  • 初始化方法

    let middleware = new MiddleWare();
  • 添加中间件函数的方法
    //Fn为被添加的中间件
    middleware.use(Fn);
  • 启动中间件队列
    middleware.start(req, res);

二. 核心类的定义

class MiddleWare{
    constructor(){
        this.queue = [];//用来存放中间件队列
    }

    //添加中间件
    use(fn){
         this.queue.push(fn);//将自定义中间件加入队列
    }

    //按次序执行中间件
    start(req, res){
        let i = 0;//执行指针

        //执行器
        const next = (err)=>{
            //如果有错误就将错误信息挂在response上并直接退出
            if(err){
                res.hasError = true;
                res.data = err.toString();
                return;
            }

            //如果没有错误就查看是否到达队尾,若没到则继续执行下一个中间件
            if(i < this.queue.length){
                this.queue[i++](req, res, next);
                /*将next直接传入当前执行的函数作为回调
                 当前执行函数执行到任何一步,通过主动调用next方法即可将相关信息传给下一个中间件。*/
            }else{
                //如果已经到队尾了则结束
                console.log(‘finish‘);
            }

        }
        //启动第一个
        next();
    }
}

三. 使用use方法添加中间件

//添加第一个中间件
/*
此处演示了一个基本的错误捕捉的写法,当中间件中出现错误时,会捕捉到错误并传入next
*/
middleware.use(function(req, res, next){
    try{
       req.addon1 = ‘I add something‘;
    }catch(err){
       next(err);
    }
    next();
});

//添加第二个中间件
middleware.use(function(req, res, next){
     res.addon2 = ‘I add something more‘;
     next();
});

//添加第三个中间件
middleware.use(function(req, res, next){
     if (req.addon2) {
       delete req.addon2;
     }
     res.addon3 = ‘I add something a lot‘;
     next();
});

四. 消费定义的类

“消费”这个词是最近学到的,觉得很装X,所以也在这里装一下~

let req = {};
let res = {};
let result = middleware.start(req,res);
console.log(req, res);

五. 查看运行结果

可以看到有错误发生和正常响应时的不同结果:

六. 在服务器端运行

node起一个web服务器那真是太随意了~

const http = require(‘http‘);
//上面的一堆代码
http.createServer(function(req, res){
    let result = {};
    middleware.start(req, result);
    res.end(JSON.stringify(result));
}).listen(9527);

看一下效果(访问服务器时自定义消息就可以传至前台了):

原文地址:http://blog.51cto.com/13869008/2177444

时间: 2024-11-05 18:56:07

【随笔】express中间件系统的基本实现的相关文章

Express中间件的意思 next()的方法

一.什么是express?Express是一个简洁.灵活的noode.jsWeb应用开发框架,它提供一系列强大的特性,帮助你创建各种Web和移动设备应用.Express项目的底层由许多的中间件在协同工作,可以这么说,一个Express应用就是在调用各种中间件.二.什么是中间件? 官方解释: 中间件是一个可访问请求对象(req)和响应对象(res)的函数,在 Express应用的请求响应循环里,下一个内联的中间件通常用变量next表示 大白话解释: 浏览器向服务器发送一个请求后,服务器直接通过re

express中间件和路由教程

一.路由1.通常HTTP URL的格式是这样的:http://host[:port][path] http表示协议. host表示主机. port为端口,可选字段,不提供时默认为80. path指定请求资源的URI(Uniform Resource Identifier,统一资源定位符),如果URL中没有给出path,一般会默认成"/"(通常由浏览器或其它HTTP客户端完成补充上). 所谓路由,就是如何处理HTTP请求中的路径部分.比如"http://xxx.com:80/u

express 中间件

[express 中间件] 中间件(Middleware) 是一个函数,它可以访问请求对象(request object (req)), 响应对象(response object (res)), 和 web 应用中处于请求-响应循环流程中的中间件,一般被命名为 next 的变量. 1.应用级中间件 应用级中间件绑定到 app 对象 使用 app.use() 和 app.METHOD(), 其中, METHOD 是需要处理的 HTTP 请求的方法,例如 GET, PUT, POST 等等,全部小写

express中间件原理 &amp;&amp; 实现

一.什么是express中间件? 什么是express中间件呢? 我们肯定都听说过这个词,并且,如果你用过express,那么你就一定用过express中间件,如下: var express = require('express'); var app = express(); app.listen(3000, function () { console.log('listening 3000') }); app.use(middleware1); app.use(middleware2); ap

Node.js连接Mysql,并把连接集成进Express中间件中

引言 在node.js连接mysql的过程,我们通常有两种连接方法,普通连接和连接池. 这两种方法较为常见,当我们使用express框架时还会选择使用中间express-myconnection,可以单独对mysql配置,也可以把connection集成到express中间件中. 最后送上一个node.js 连接各种主流数据库示例代码. 前提条件 1.安装mysql对应的驱动,npm install mysql 2.安装第三方插件express-connection, npm install e

express中间件的理解

官网对它的阐述是这样的: "Express是一个自身功能极简,完全是路由和中间件构成一个web开发框架:从本质上来说,一个Express应用就是在调用各种中间件." 由此可见,中间件在Express开发中的重要性,因此这里我们就专门来总结一下中间件. 一.中间件结构 app.use([path],function) path:是路由的url,默认参数'/',意义是路由到这个路径时使用这个中间件 function:中间件函数 这个中间件函数可以理解为就是function(request,

express中间件

"Express是一个自身功能极简,完全是路由和中间件构成一个web开发框架:从本质上来说,一个Express应用就是在调用各种中间件." 由此可见,中间件在Express开发中的重要性,因此这里我们就专门来总结一下中间件. 一.中间件结构 1.app.use([path],function) path:是路由的url,默认参数'/',意义是路由到这个路径时使用这个中间件 function:中间件函数 这个中间件函数可以理解为就是function(request,response,ne

Express中间件简单的实现原理

上一篇理解Express的使用之后, 再总结一篇Express中间件的简单实现原理. 我们知道Express中间件就是一个个的函数, 那么怎么让这些函数有序的执行呢? 那就需要我们调用 next 函数.其实 next函数调用的就是下一个中间件函数. 以下代码实现了简单的 app.use 注册中间件, 以及 get.post方式的中间件.其他请求方式的中间件实现同理 核心代码: const next = () => { const stack = stacks.shift() if(stack)

中间件系统的架构设计

中间件系统的架构设计 Master-Slave架构   该系统的本质是希望能够用分布式的方式来处理一些数据,核心思想,就是把数据分发到很多台机器上来处理,然后需要有一台机器来控制N多台机器的分布式处理: 分布式的处理,就会肯定涉及到在Master中要维护这个集群的一些核心元数据.数据的分发处理的调度,处理的具体过程的进度,对集群里存放数据进行描述的一些核心元数据. 这些核心元数据会不断的频繁的修改,无论你是基于外部的文件还是数据库,或者是zookeeper来存放这些元数据的话,其实都会导致他的元