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

2019-01-12  本文已影响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');
})

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

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

上一篇下一篇

猜你喜欢

热点阅读