一、引入Express框架
1.安装并加载Express模块
1 | npm install express -g |
1 | let express = require('express') |
2.编写响应和绑定端口号
在Express框架下,不再需要更改响应头,其具有自动识别并更改响应头的能力。
1 | app.get('/',(req,res)=>{ |
3.设置静态空间
在被设置为静态空间的文件夹下的文件可以被终端直接访问,例如:
1 | /* |
4.在express中使用art-template
使用express-art-tempalte
虽然不需要再载入art-template
,但是前者是基于后者的,所以使用前者必须安装后者。
安装express-art-template
模块后,使用方法如下:
1 | app.engine('html',require('express-art-template')) |
注意
render中的文件无需加入路径,默认访问当前文件夹下的
views
文件夹下的对应文件,如需更改可以使用:1
app.set('views',更改的默认目录+'/')
5.在express中解析post请求的数据
需要先安装中间件-body-parser
,然后根据以下命令配置
1 | let bodyParser = require('body-parser') |
6.构建路由
1 | router = express.Router() |
7.构建项目链
- 构建入口函数
- 设计路由
- 设计API
- 具体实现
1 | app.js <--- router.js <--- APIname.js |
二、Session
express-session中间件
配置:
1 | let session = require('express-session') |
三、关于Express中的中间件
3.1 中间件
中间件middleware
就是一个为你增加功能的方法。配置好对应的中间件之后,我们就能使用对应的功能了。在Node.js
中,中间件一般都是处理请求的req,res
3.2 Express中间件按关心内容分类
中间件 | 参数 | 功能 | 类型 |
---|---|---|---|
use | (req,res,next)=>{} | 不论收到来自客户端的任何请求,都会执行参数里的方法。next()代表自动执行下一个中间件 | 不关心请求路径和请求方式的中间件 |
use | ‘/xxx’,(req,res,next)=>{} | 当请求路径以第一个参数开头时,则执行第二个参数的方法 | 关心请求路径但不关心请求方式的中间件 |
get、post | ‘/xxx’,(req,res,next)=>{} | 当对应get、post请求的请求路径为对应的第一个参数时执行 | 严格按照请求路径并关心请求方式的中间件 |
3.3 中间件匹配策略
- 如果匹配到第一个符合条件的中间件
- 如果没有next则结束匹配
- 如果执行了next()则继续匹配下一个符合条件的中间件
- 如果没有匹配到,则继续向下找满足条件的中间件
3.4 使用中间件配置404和全局错误处理
1 | //example... |