美文网首页
【深入浅出express】- express入门01

【深入浅出express】- express入门01

作者: 张举欣 | 来源:发表于2019-01-12 15:30 被阅读19次

    简介

    Express是目前流行的基于Node.js的Web开发框架,提供各种模块,可以快速地搭建一个具有完整功能的网站。

    中间件

    说到中间件,官网对它的阐述是这样的:

    “Express是一个自身功能极简,完全是路由和中间件构成一个web开发框架:从本质上来说,一个Express应用就是在调用各种中间件。”
    由此可见,中间件在Express开发中的重要性,因此这里我们就专门来总结一下中间件。
    首先来一个例子:

    app.use('/water', function(req, res, next) {
        console.log(`过滤石头`);
        req.stone = 'too big';
        next();
    })
    app.use('/water', function(req, res, next) {
        console.log(`过滤沙子`);
        req.stone = 'too big';
        next();
    })
    app.get('/water', function(req, res) {
        console.log(req.stone); //这里的req和上面的中间件是同一个
        res.end('water');
    })
    

    上面每一个app.use()都是一个中间件,如果我们访问/water这个路由,首先会经过上面的两个中间件,第一个中间件给req.stone加了一个属性,第二个中间件也给req.stone加了一个属性,在最后/water路由里面我们打印一下req.stone,结果显示的是‘too big’,所以上面两个中间件和下面的路由共用一个req 。

    举个例子,如果我们想从浑水中得到清水,我们需要几步过滤,过滤沙子,过滤石头。。。
    如果访问/water这个路由我们就可以得到清水,那么上面的几个中间件就是过滤器,第一个是过滤石头的,第二个是过滤沙子的。
    从上面的代码外面可以得出几个中间件的特点:
    必须放到处理特定路由的上面
    每个中间件的参数和他们对应的路由的参数是同一个
    说了那么多,下面外面正式说一下中间件吧!

    一、中间件结构

    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'));
    
    2.自定义中间件

    自定义中间件就是我们自己写的中间件。
    在上面中间件结构中,我们知道了,中间件使用时的第二个参数是一个Function,然而,要自定义一个中间件,就是倒腾一番这个Function,这个function有三个参数(req,res, next)

    当每个请求到达服务器时,nodejs会为请求创建一个请求对象(request),该请求对象包含客户端提交上来的数据。同时也会创建一个响应对象(response),响应对象主要负责将服务器的数据响应到客户端。而最后一个参数next是一个方法,因为一个应用中可以使用多个中间件,而要想运行下一个中间件,那么上一个中间件必须运行next()。

    3、第三方中间件

    有关第三方中间件,这里我们分析几个比较重要和常用的,知道这几个的使用,其它的也就会了。

    body-parser :解析body中的数据,并将其保存为Request对象的body属性。

    cookie-parser :解析客户端cookie中的数据,并将其保存为Request对象的cookie属性

    express-session :解析服务端生成的sessionid对应的session数据,并将其保存为Request对象的session属性

    query:这个中间件将一个查询字符串从URL转换为JS对象,并将其保存为Request对象的query属性。这个中间件在第四个版本中已经内置了无需安装。


    错误中间件

    错误中间件参数有四个,放在代码的最后面,next()如果传了参数直接走错误的中间件

    app.use(function(err, req, res, next) {
        console.log('err');
    })
    
    全匹配的中间件
    app.use(function(req, res, next) {
        console.log('err');
    })
    

    像这种参数只有一个函数的中间件可以匹配全部的路由

    未完待续,敬请期待。。。

    相关文章

      网友评论

          本文标题:【深入浅出express】- express入门01

          本文链接:https://www.haomeiwen.com/subject/nrlcdqtx.html