使用 Node.js 和 Express 构建 RESTful API 服务器

简介: 【10月更文挑战第3天】使用 Node.js 和 Express 构建 RESTful API 服务器

使用 Node.js 和 Express 构建 RESTful API 服务器

Node.js 是一个基于 Chrome V8 JavaScript 引擎的 JavaScript 运行环境,它允许开发者使用 JavaScript 编写服务器端的应用程序。Express 则是一个基于 Node.js 的 Web 应用框架,它简化了 Web 应用的开发过程。在本文中,我们将构建一个简单的 RESTful API 服务器,该服务器能够处理 CRUD 操作(创建、读取、更新、删除)。

1. 环境准备

首先,确保你的开发环境中已经安装了 Node.js。接下来,我们需要创建一个新的 Node.js 项目。

打开终端或命令提示符,执行以下命令来创建一个新的项目目录:

mkdir express-api-server
cd express-api-server
npm init -y

2. 安装依赖

我们需要安装 express 作为我们的 Web 框架,以及 body-parser 来解析请求体中的 JSON 数据。

npm install express body-parser

3. 创建服务器

接下来,我们将创建一个简单的 HTTP 服务器。在项目根目录下创建一个名为 server.js 的文件,并添加以下代码:

const express = require('express');
const bodyParser = require('body-parser');

// 创建 Express 应用实例
const app = express();

// 使用 body-parser 中间件来解析 JSON 请求体
app.use(bodyParser.json());

// 设置监听端口
const PORT = process.env.PORT || 3000;

// 启动服务器
app.listen(PORT, () => {
   
  console.log(`Server is running on port ${
     PORT}`);
});

4. 设计数据模型

我们将使用一个简单的内存数组来模拟数据库操作。在 server.js 中添加一个模拟数据模型:

let todos = [
  {
    id: 1, title: '学习 Node.js', completed: false },
  {
    id: 2, title: '练习 Express', completed: true },
];

// 用于生成唯一 ID 的辅助函数
function generateId() {
   
  return Math.floor(Math.random() * 100000);
}

5. 实现 RESTful API

接下来,我们将为 CRUD 操作实现对应的 HTTP 路由。

GET 请求

首先,实现一个 GET 请求来获取所有的待办事项:

app.get('/todos', (req, res) => {
   
  res.status(200).json(todos);
});
POST 请求

接着,实现一个 POST 请求来添加新的待办事项:

app.post('/todos', (req, res) => {
   
  const newTodo = {
   
    id: generateId(),
    title: req.body.title,
    completed: false,
  };
  todos.push(newTodo);
  res.status(201).json(newTodo);
});
PUT 请求

实现一个 PUT 请求来更新现有的待办事项:

app.put('/todos/:id', (req, res) => {
   
  const id = parseInt(req.params.id, 10);
  const updatedTodo = req.body;
  const todoIndex = todos.findIndex(todo => todo.id === id);

  if (todoIndex !== -1) {
   
    todos[todoIndex] = {
    ...todos[todoIndex], ...updatedTodo };
    res.status(200).json(todos[todoIndex]);
  } else {
   
    res.status(404).send('Todo not found');
  }
});
DELETE 请求

最后,实现一个 DELETE 请求来删除特定的待办事项:

app.delete('/todos/:id', (req, res) => {
   
  const id = parseInt(req.params.id, 10);
  const todoIndex = todos.findIndex(todo => todo.id === id);

  if (todoIndex !== -1) {
   
    todos.splice(todoIndex, 1);
    res.status(204).send();
  } else {
   
    res.status(404).send('Todo not found');
  }
});

6. 测试 API

启动服务器:

node server.js

现在,你可以使用 Postman 或者 curl 等工具来测试这些 API。

例如,使用 curl 发送一个 POST 请求:

curl -X POST http://localhost:3000/todos -H "Content-Type: application/json" -d '{"title":"学习 Express"}'

7. 总结

通过这篇文章,我们成功地使用 Node.js 和 Express 构建了一个简单的 RESTful API 服务器,它能够处理基本的 CRUD 操作。这个例子展示了如何创建一个 HTTP 服务器,如何接收和发送 JSON 数据,以及如何使用中间件来处理请求体。


相关文章
|
6月前
|
XML JSON API
识别这些API接口定义(http,https,api,RPC,webservice,Restful api ,OpenAPI)
本内容介绍了API相关的术语分类,包括传输协议(HTTP/HTTPS)、接口风格(RESTful、WebService、RPC)及开放程度(API、OpenAPI),帮助理解各类API的特点与应用场景。
|
8月前
|
缓存 安全 API
RESTful与GraphQL:电商API接口设计的技术细节与适用场景
本文对比了RESTful与GraphQL这两种主流电商API接口设计方案。RESTful通过资源与HTTP方法定义操作,简单直观但可能引发过度或欠获取数据问题;GraphQL允许客户端精确指定所需字段,提高灵活性和传输效率,但面临深度查询攻击等安全挑战。从性能、灵活性、安全性及适用场景多维度分析,RESTful适合资源导向场景,GraphQL则适用于复杂数据需求。实际开发中需根据业务特点选择合适方案,或结合两者优势,以优化用户体验与系统性能。
|
8月前
|
JSON 编解码 API
Go语言网络编程:使用 net/http 构建 RESTful API
本章介绍如何使用 Go 语言的 `net/http` 标准库构建 RESTful API。内容涵盖 RESTful API 的基本概念及规范,包括 GET、POST、PUT 和 DELETE 方法的实现。通过定义用户数据结构和模拟数据库,逐步实现获取用户列表、创建用户、更新用户、删除用户的 HTTP 路由处理函数。同时提供辅助函数用于路径参数解析,并展示如何设置路由器启动服务。最后通过 curl 或 Postman 测试接口功能。章节总结了路由分发、JSON 编解码、方法区分、并发安全管理和路径参数解析等关键点,为更复杂需求推荐第三方框架如 Gin、Echo 和 Chi。
|
7月前
|
缓存 边缘计算 前端开发
从业务需求到技术栈:电商API选型RESTful还是GraphQL?这5个维度帮你决策
在数字经济时代,电商平台的竞争已延伸至用户体验与系统效能。作为连接前后端及各类服务的核心,API接口的架构设计至关重要。本文对比RESTful与GraphQL两大主流方案,从电商场景出发,分析两者的技术特性、适用场景与选型逻辑,帮助开发者根据业务需求做出最优选择。
|
10月前
|
前端开发 JavaScript NoSQL
使用 Node.js、Express 和 React 构建强大的 API
本文详细介绍如何使用 Node.js、Express 和 React 构建强大且动态的 API。从开发环境搭建到集成 React 前端,再到利用 APIPost 高效测试 API,适合各水平开发者。内容涵盖 Node.js 运行时、Express 框架与 React 库的基础知识及协同工作方式,还涉及数据库连接和前后端数据交互。通过实际代码示例,助你快速上手并优化应用性能。
|
11月前
|
Kubernetes API 网络安全
当node节点kubectl 命令无法连接到 Kubernetes API 服务器
当Node节点上的 `kubectl`无法连接到Kubernetes API服务器时,可以通过以上步骤逐步排查和解决问题。首先确保网络连接正常,验证 `kubeconfig`文件配置正确,检查API服务器和Node节点的状态,最后排除防火墙或网络策略的干扰,并通过重启服务恢复正常连接。通过这些措施,可以有效解决与Kubernetes API服务器通信的常见问题,从而保障集群的正常运行。
872 17
|
11月前
|
机器学习/深度学习 设计模式 API
Python 高级编程与实战:构建 RESTful API
本文深入探讨了使用 Python 构建 RESTful API 的方法,涵盖 Flask、Django REST Framework 和 FastAPI 三个主流框架。通过实战项目示例,详细讲解了如何处理 GET、POST 请求,并返回相应数据。学习这些技术将帮助你掌握构建高效、可靠的 Web API。
|
11月前
|
JavaScript 前端开发 API
JavaScript中通过array.map()实现数据转换、创建派生数组、异步数据流处理、复杂API请求、DOM操作、搜索和过滤等,array.map()的使用详解(附实际应用代码)
array.map()可以用来数据转换、创建派生数组、应用函数、链式调用、异步数据流处理、复杂API请求梳理、提供DOM操作、用来搜索和过滤等,比for好用太多了,主要是写法简单,并且非常直观,并且能提升代码的可读性,也就提升了Long Term代码的可维护性。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
JavaScript 前端开发 安全
盘点原生JS中目前最没用的几个功能API
在JavaScript的发展历程中,许多功能与API曾风光无限,但随着技术进步和语言演化,部分功能逐渐被淘汰或被更高效的替代方案取代。例如,`with`语句使代码作用域复杂、可读性差;`void`操作符功能冗余且影响可读性;`eval`函数存在严重安全风险和性能问题;`unescape`和`escape`函数已被`decodeURIComponent`和`encodeURIComponent`取代;`arguments`对象则被ES6的剩余参数语法替代。这些变化体现了JavaScript不断优化的趋势,开发者应紧跟技术步伐,学习新技能,适应新技术环境。
244 10