node.js 学习入门(07 - express 模块创建基本 web 服务器)(上)

简介: node.js 学习入门(07 - express 模块创建基本 web 服务器)

1. 什么是 express?

Express 是一个简洁而灵活的 node.js Web应用框架, 提供了一系列强大特性帮助你创建各种 Web 应用,和丰富的 HTTP 工具。

使用 Express 可以快速地搭建一个完整功能的网站。

Express 框架核心特性:

可以设置中间件来响应 HTTP 请求。

定义了路由表用于执行不同的 HTTP 请求动作。

可以通过向模板传递参数来动态渲染 HTML 页面。

2. 如何安装 express?

npm install express
3. 使用 express 创建一个基本的 web 服务器

以下实例中我们引入了 express 模块,并在客户端发起请求后,响应 {name:‘张三’,age:18,sex:‘男’,id:1} 对象,如果加入动态参数 ‘/1’ 可以返回 {id:1}。也可以使用 post 请求向客户端响应一个文本字符串。

// 1. 导入 express
const express = require('express')
// 2. 创建 web 服务器
const app = express()
// 4. 监听客户端的 GET 和 POST 请求,并向客户端响应具体的内容
app.get('/user', (req, res) => {
    // 调用 express 提供的 res.send() 方法,向客户端响应一个 JSON 对象
    res.send({name:'张三',age:18,sex:'男',id:1})
})
app.post('/user', (req, res) => {
    // 调用 express 提供的 res.send() 方法,向客户端响应一个文本字符串
    res.send("请求成功")
})
app.get('/', (req, res) => {
    // 通过 req.query 可以获取到客户端发送过来的 查询参数
    // 注意:默认情况下,req.query 是一个空对象
    console.log(req.query)
    res.send(req.query)
})
// 注意:这里的 :id 是一个动态的参数
app.get('/user/:id', (req, res) => {
    // req.params 是动态匹配到的 URL 参数,默认也是一个空对象
    // 可以有多个动态参数   '/user/:id/:name'
    console.log(req.params)
    res.send(req.params)
})
// 3. 启动 web 服务器
app.listen(80, () => {
    console.log("express server running at http://127.0.0.1")
})

4. 使用express.static对外提供静态资源

express.static() 方法,获取 html 页面中的内容,并显示在浏览器中,可以在前面加入一个参数,这样就需要接口加上参数才可以请求到页面信息。app.use() 的作用就是注册全局中间件

const express = require('express')
const app = express()
// 在这里,调用 express.static() 方法,快速的对外提供静态资源
// 如果有多个,会先查找在前的
app.use('/files',express.static('./files'))
app.use(express.static('./clock'))
app.listen(80, () => {
    console.log("express server running at http://127.0.0.1")
})

5. 模块化路由

可以把一个页面拆分开,在入口文件引入,请求的接口页面

  • 入口页面
const express = require('express')
const app = express()
// 1. 导入路由模块
const router = require('./05-router')
// 2. 注册路由模块
// 添加统一的访问前缀
app.use('/api',router)
// 注意:app.use() 的作用就是注册全局中间件
app.listen(80, () => {
    console.log("express server running at http://127.0.0.1")
})
  • 接口页面
// 这是路由模块
// 1. 导入 express
const express = require('express')
// 2. 创建路由对象
const router = express.Router()
// 3. 挂载具体的路由
router.get('/user/list', (req, res) => {
    res.send("Get user list.")
})
router.post('/user/add', (req, res) => {
    res.send("Post user add.")
})
// 4. 向外导出路由对象
module.exports = router

6. 定义中间件函数

中间件函数要写在路由之前,路由里可以调用中间件函数里定义的方法

const express = require('express')
const app = express()
// 定义一个简化的中间件
app.use((req, res, next) => {
    // 获取到请求到达服务器的时间
    const time = Date.now()
    // 为 req 对象,挂载自定义属性,从而把时间共享给后面的所有路由
    req.startTime = time
    next()
})
app.get('/', (req, res) => {
    res.send("Home page."+req.startTime)
})
app.get('/user', (req, res) => {
    res.send("User page."+req.startTime)
})
app.listen(80, () => {
    console.log("express server running at http://127.0.0.1")
})

7. 局部生效的中间件

只在引入中间件的路由里有效

const express = require('express')
const app = express()
// 定义一个局部的中间件
const mw1 = (req, res, next) => {
    console.log("调用了第一个生效的局部中间件")
    next()
}
// 定义一个局部的中间件
const mw2 = (req, res, next) => {
    console.log("调用了第二个生效的局部中间件")
    next()
}
// 创建路由
// 局部中间件只在当前有效
// 可以使用多个,有二种方法 mw1,mw2   [mw1,mw2]
app.get('/',mw1,mw2, (req, res) => {
    res.send("Home page.")
})
app.get('/user', (req, res) => {
    res.send("User page.")
})
app.listen(80, () => {
    console.log("express server running at http://127.0.0.1")
})

8. 错误级别中间件的使用

可以防止程序的崩溃

const express = require('express')
const app = express()
// 定义路由
app.get('/', (req, res) => {
    // 1.1 人为制造错误
    throw new Error('服务器内部发生错误')
    res.send("Home page.")
})
// 定义一个错误级别的中间件,捕获整个项目的异常信息,从而防止程序的崩溃
app.use((err,req, res, next) => {
    console.log("发生了错误" + err.message)
    res.send('Error' + err.message)
})
app.listen(80, () => {
    console.log("express server running at http://127.0.0.1")
})
相关文章
|
1月前
|
JavaScript 前端开发 开发者
VUE 开发——Node.js学习(一)
VUE 开发——Node.js学习(一)
64 3
|
1月前
使用 Node 创建 Web 客户端
使用 Node 创建 Web 客户端
114 4
|
1月前
|
开发框架 JavaScript 前端开发
使用 Node.js 和 Express 构建 Web 应用
【10月更文挑战第2天】使用 Node.js 和 Express 构建 Web 应用
|
15天前
|
缓存 负载均衡 监控
性能优化:Node.js高效服务器开发技巧与最佳实践
【10月更文挑战第29天】在Node.js服务器开发中,性能优化至关重要。本文介绍了几种高效开发的最佳实践,包括使用缓存策略、采用异步编程、实施负载均衡和性能监控。通过示例代码展示了如何实现这些技术,帮助开发者构建更快、更稳定的Node.js应用。
33 2
|
22天前
|
JavaScript 前端开发 持续交付
构建现代Web应用:Vue.js与Node.js的完美结合
【10月更文挑战第22天】随着互联网技术的快速发展,Web应用已经成为了人们日常生活和工作的重要组成部分。前端技术和后端技术的不断创新,为Web应用的构建提供了更多可能。在本篇文章中,我们将探讨Vue.js和Node.js这两大热门技术如何完美结合,构建现代Web应用。
21 4
|
1月前
|
JSON JavaScript 前端开发
使用 Node.js 和 Express 构建 RESTful API 服务器
【10月更文挑战第3天】使用 Node.js 和 Express 构建 RESTful API 服务器
|
1月前
|
Web App开发 JavaScript 前端开发
使用Node.js和Express框架构建Web服务器
使用Node.js和Express框架构建Web服务器
|
2月前
|
Web App开发 JavaScript 前端开发
构建高效Web应用:Node.js与Express框架的深度整合
【9月更文挑战第28天】在现代Web开发领域,Node.js和Express框架的结合已成为打造高性能、易扩展应用的黄金组合。本文将深入探讨如何利用这一技术栈优化Web应用架构,提供具体实践指导,并分析其性能提升的内在机制。通过代码示例,我们将展示从基础搭建到高级功能的实现过程,旨在为开发者提供一条清晰的学习路径,以实现技术升级和项目效率的双重提升。
48 3
|
1月前
|
JSON JavaScript 前端开发
使用JavaScript和Node.js构建简单的RESTful API服务器
【10月更文挑战第12天】使用JavaScript和Node.js构建简单的RESTful API服务器
17 0
|
1月前
|
JavaScript 应用服务中间件 Apache
Node.js Web 模块
10月更文挑战第7天
30 0