Express教程01:建立服务器、配置路由

阅读更多系列文章请访问个人GitHub博客,示例代码请访问这里

Express介绍

基于 Node.js 平台,快速、开放、极简的 Web 开发框架。html

Express的特色是易于入门,并且可使用各类中间件扩展它的功能。node

但因为Express开发相对较早,主要使用回调函数进行异步操做,没法使用Async函数,所以原团队也开发了功能更强大的Koa来解决Express的不足之处。git

不过对于开发人员,Express仍是不可或缺的一项重要技能。github

使用Express建立服务器

示例代码:/lesson01/server.jsexpress

  1. /lesson01文件夹经过npm init -y初始化项目
  2. 使用npm install express --save安装Express
  3. 引用Express并建立服务器
const express = require('express')

const server = express()

server.listen(8080)

console.log(`Server started at 8080`)
复制代码

经常使用路由配置方法

示例代码:/lesson01/server.jsnpm

一般接收到的请求不止get方法,经常使用的有:json

  1. server.get,处理get请求
  2. server.post,处理post请求
  3. server.use,处理全部方法的请求,它的第一个路由参数能够不传,此时表示处理全部接口请求,以下:
server.use('/first', (req, res, next) => {
  console.log('first')
  next()
})
复制代码

除了这3个方法以外,还有server.put、server.delete等方法,具体能够查看文档api

添加路由

示例代码:/lesson01/server.jsbash

Express自带了路由功能,不须要引用中间件便可添加路由。服务器

server.get('/first', (req, res, next) => {
  res.send({
    error: 0,
    msg: '请求成功'
  })
})
复制代码

代码含义以下:

  1. 建立了一个get请求的路由。
  2. 第一个参数'/first'表示请求的路由名称。
  3. 第二个参数为回调函数。
  4. 回调函数传参req表示请求参数实例。
  5. 回调函数传参res表示响应参数实例。
  6. next用于触发下一步操做。
  7. res.send能够向前台发送数据,与原生node.js的res.write方法不一样,它不止能够发送Buffer、字符串,还能够直接发送JSON等数据,以下:
res.send(new Buffer('wahoo'));
res.send({ some: 'json' });
res.send('<p>some html</p>');
res.send(404, 'Sorry, cant find that');
res.send(404);
复制代码

此时访问http://localhost:8080/first,便可看到页面显示:{"error":0,"msg":"请求成功"}

next方法的使用

示例代码:/lesson01/server.js

next方法的做用是用于对请求的多级处理,例如:

server.get('/second', (req, res, next) => {
  if (Number(req.query.num) > 10) {
    // 知足条件时,才可触发同名的下一个路由。
    next()
  } else {
    res.send({
      error: 1,
      msg: '请输入大于10的数字'
    })
  }
})

server.get('/second', (req, res, next) => {
  res.send({
    error: 0,
    msg: '输入成功'
  })
})
复制代码

代码含义以下:

  1. 若配置了多个同名路由,代码会从上到下按顺序执行,但若是未调用next方法,执行过程会中断。
  2. 若是接口传参为http://localhost:8080/second?num=8,没法知足num > 10的条件,则不会执行第二个/second路由回调函数中代码,直接返回错误。
  3. 若是接口传参为http://localhost:8080/second?num=80,知足了num > 10的条件,则能够执行第二个/second路由回调函数中代码,进行下一步处理。
  4. next方法在处理中间件时十分有用,由于在各级中间件的处理中,能够经过next方法判断是否须要执行下一级处理,

next方法传参

示例代码:/lesson01/server.js

有时会须要给下一级的处理传参,只要直接给req实例中添加属性便可,但请注意不要覆盖系统默认属性,以下:

server.get('/second', (req, res, next) => {
  if (Number(req.query.num) > 10) {
    // 知足条件时,才可触发同名的下一个路由。
    req.randomNum = Math.floor(Math.random() * 100)
    next()
  } else {
    res.send({
      error: 1,
      msg: '请输入大于10的数字'
    })
  }
})

server.get('/second', (req, res, next) => {
  res.send({
    error: 0,
    msg: `输入成功,接收到的随机数为${req.randomNum}`
  })
})
复制代码

访问http://localhost:8080/second?num=80便可看到前台打印出的req.randomNum结果。

相关文章
相关标签/搜索