Node.js 路由 - 初识 Express 中的路由

目录

[Node.js 路由 - 初识 Express 中的路由](#Node.js 路由 - 初识 Express 中的路由)

[1. 什么是路由?](#1. 什么是路由?)

[2. 安装 Express](#2. 安装 Express)

[3. 创建 server.js](#3. 创建 server.js)

[4. 运行服务器](#4. 运行服务器)

[5. 测试路由](#5. 测试路由)

[5.1 访问主页](#5.1 访问主页)

[5.2 访问用户路由](#5.2 访问用户路由)

[5.3 发送 POST 请求](#5.3 发送 POST 请求)

[6. 结语](#6. 结语)


1. 什么是路由?

路由(Routing)是指根据不同的 URL 地址,服务器返回不同的内容 。在 Express 中,我们可以使用 app.get()app.post() 等方法定义路由。


2. 安装 Express

bash 复制代码
mkdir express-routing && cd express-routing  # 创建项目目录
npm init -y  # 初始化项目
npm install express  # 安装 Express

3. 创建 server.js

文件名:server.js(JavaScript 代码)

javascript 复制代码
// server.js
const express = require('express'); // 引入 Express
const app = express(); // 创建应用
const port = 3000; // 服务器端口

// 主页路由
app.get('/', (req, res) => {
    res.send('欢迎来到 Express 主页!');
});

// 用户路由(GET 请求)
app.get('/user/:name', (req, res) => {
    const name = req.params.name; // 获取 URL 参数
    res.send(`你好,${name}!`);
});

// 提交数据路由(POST 请求)
app.use(express.json()); // 解析 JSON 请求体
app.post('/submit', (req, res) => {
    const { username, age } = req.body; // 获取请求体数据
    res.json({ message: '数据提交成功', user: { username, age } });
});

// 启动服务器
app.listen(port, () => {
    console.log(`服务器运行在 http://localhost:${port}`);
});

4. 运行服务器

执行命令:

bash 复制代码
node server.js

5. 测试路由

5.1 访问主页

浏览器打开 http://localhost:3000/,页面显示:

javascript 复制代码
欢迎来到 Express 主页!
5.2 访问用户路由

浏览器访问 http://localhost:3000/user/Tom,页面显示:

javascript 复制代码
你好,Tom!
5.3 发送 POST 请求

使用 Postman 或 curl 发送请求:

javascript 复制代码
curl -X POST http://localhost:3000/submit -H "Content-Type: application/json" -d '{"username": "Alice", "age": 25}'

服务器返回 JSON 响应:

javascript 复制代码
{
    "message": "数据提交成功",
    "user": {
        "username": "Alice",
        "age": 25
    }
}

6. 结语

本文介绍了 Express 路由 的基本用法,包括 GET 和 POST 请求,以及如何获取 URL 参数和请求体数据。希望这篇教程能帮助你快速上手 Express 路由!🚀

相关推荐
excel1 分钟前
前端事件机制入门到精通:事件流、冒泡捕获与事件委托全解析
前端
Moment18 分钟前
Next.js 15.5 带来 Turbopack Beta、Node 中间件稳定与 TypeScript 强化 🚀🚀🚀
前端·javascript·react.js
Zeluar24 分钟前
关闭VSCode Markdown插件在Jupyter Notebook中的自动预览
ide·vscode·jupyter
yzzzzzzzzzzzzzzzzz41 分钟前
初识javascript
前端·javascript
excel2 小时前
硬核 DOM2/DOM3 全解析:从命名空间到 Range,前端工程师必须掌握的底层知识
前端
专注API从业者9 小时前
Python + 淘宝 API 开发:自动化采集商品数据的完整流程
大数据·运维·前端·数据挖掘·自动化
你的人类朋友10 小时前
【Node&Vue】JS是编译型语言还是解释型语言?
javascript·node.js·编程语言
烛阴10 小时前
TypeScript高手密技:解密类型断言、非空断言与 `const` 断言
前端·javascript·typescript
样子201810 小时前
Uniapp 之renderjs解决swiper+多个video卡顿问题
前端·javascript·css·uni-app·html
Nicholas6811 小时前
flutterAppBar之SystemUiOverlayStyle源码解析(一)
前端