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")
})
相关文章
|
20天前
|
JavaScript 前端开发
在Node.js中,如何合理使用模块来避免全局变量的问题?
在Node.js中,如何合理使用模块来避免全局变量的问题?
58 15
|
22天前
|
JavaScript 前端开发 开发者
Node学习笔记:HTTP模块
总的来说,Node.js的HTTP模块是一个强大的工具,可以帮助你处理HTTP协议的各种需求。无论你是想开设自己的餐厅(创建服务器),还是想去别的餐厅点菜(发出请求),HTTP模块都能满足你的需求。
62 18
|
6月前
|
JavaScript
使用Node.js创建一个简单的Web服务器
使用Node.js创建一个简单的Web服务器
|
6月前
|
JavaScript 前端开发 持续交付
构建现代Web应用:Vue.js与Node.js的完美结合
【10月更文挑战第22天】随着互联网技术的快速发展,Web应用已经成为了人们日常生活和工作的重要组成部分。前端技术和后端技术的不断创新,为Web应用的构建提供了更多可能。在本篇文章中,我们将探讨Vue.js和Node.js这两大热门技术如何完美结合,构建现代Web应用。
116 4
|
7月前
|
JavaScript 应用服务中间件 Apache
Node.js Web 模块
10月更文挑战第7天
65 0
|
7月前
|
JavaScript 网络协议
Node.js 工具模块
10月更文挑战第7天
62 0
|
2月前
|
关系型数据库 MySQL 数据库
基于Flink CDC 开发,支持Web-UI的实时KingBase 连接器,三大模式无缝切换,效率翻倍!
TIS 是一款基于Web-UI的开源大数据集成工具,通过与人大金仓Kingbase的深度整合,提供高效、灵活的实时数据集成方案。它支持增量数据监听和实时写入,兼容MySQL、PostgreSQL和Oracle模式,无需编写复杂脚本,操作简单直观,特别适合非专业开发人员使用。TIS率先实现了Kingbase CDC连接器的整合,成为业界首个开箱即用的Kingbase CDC数据同步解决方案,助力企业数字化转型。
372 5
基于Flink CDC 开发,支持Web-UI的实时KingBase 连接器,三大模式无缝切换,效率翻倍!
|
7月前
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
416 3
|
2月前
|
机器学习/深度学习 开发框架 API
Python 高级编程与实战:深入理解 Web 开发与 API 设计
在前几篇文章中,我们探讨了 Python 的基础语法、面向对象编程、函数式编程、元编程、性能优化、调试技巧以及数据科学和机器学习。本文将深入探讨 Python 在 Web 开发和 API 设计中的应用,并通过实战项目帮助你掌握这些技术。
|
6月前
|
存储 前端开发 JavaScript
如何在项目中高效地进行 Web 组件化开发
高效地进行 Web 组件化开发需要从多个方面入手,通过明确目标、合理规划、规范开发、加强测试等一系列措施,实现组件的高效管理和利用,从而提高项目的整体开发效率和质量,为用户提供更好的体验。
165 63

热门文章

最新文章