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 路由!🚀

相关推荐
键盘鼓手苏苏2 小时前
Flutter for OpenHarmony:markdown 纯 Dart 解析引擎(将文本转化为结构化 HTML/UI) 深度解析与鸿蒙适配指南
前端·网络·算法·flutter·ui·html·harmonyos
芭拉拉小魔仙8 小时前
企业级Vue项目的状态管理:从原理到实战架构
前端·vue.js·架构
恋猫de小郭8 小时前
丰田正在使用 Flutter 开发游戏引擎 Fluorite
android·前端·flutter
扶苏10028 小时前
Vue 3 响应式原理深度解析
前端·javascript·vue.js
NEXT068 小时前
React 性能优化:图片懒加载
前端·react.js·面试
PineappleCoder9 小时前
别让字体拖了后腿:FOIT/FOUT 深度解析与字体加载优化全攻略
前端·性能优化
NEXT069 小时前
后端跑路了怎么办?前端工程师用 Mock.js 自救实录
前端·后端·程序员
装不满的克莱因瓶10 小时前
Java7新特性:try-with-resources写法
java·前端·javascript·jdk·新特性·jdk7
SailingCoder11 小时前
【 从“打补丁“到“换思路“ 】一次企业级 AI Agent 的架构拐点
大数据·前端·人工智能·面试·架构·agent
~央千澈~12 小时前
抖音弹幕游戏开发之第12集:添加冷却时间机制·优雅草云桧·卓伊凡
java·服务器·前端