0

0

使用 Node.js/Express 处理 POST 请求数据并在另一函数中应用

碧海醫心

碧海醫心

发布时间:2025-10-08 09:48:01

|

793人浏览过

|

来源于php中文网

原创

使用 node.js/express 处理 post 请求数据并在另一函数中应用

本文旨在指导开发者如何在使用 Node.js 和 Express 框架时,正确地处理 POST 请求接收到的数据,并将其传递到另一个函数中进行进一步处理。我们将重点关注服务器端的数据接收和处理,以及客户端如何通过 AJAX 请求获取处理后的数据,并最终在前端页面动态构建内容。

后端 (server.js) 数据接收与处理

首先,确保你的 Express 应用正确配置了中间件,以便能够解析 POST 请求体中的数据。常用的中间件包括 express.json() 和 express.urlencoded({ extended: true })。

const express = require('express');
const http = require('http');
const app = express();

// 添加中间件以解析 JSON 格式的请求体
app.use(express.json());
// 添加中间件以解析 URL 编码格式的请求体
app.use(express.urlencoded({ extended: true }));

app.post("/movies", function (req, res) {
  const imdbIDs = req.body;

  if (!Array.isArray(imdbIDs)) {
    return res.status(400).send("Invalid input: imdbIDs must be an array.");
  }

  const apiKey = 'YOUR_API_KEY'; // 替换为你的OMDb API密钥
  const movies = [];
  let completedRequests = 0; // 用于跟踪已完成的请求数量

  if (imdbIDs.length === 0) {
    return res.status(200).send(movies); // 如果imdbIDs为空,直接返回空数组
  }

  imdbIDs.forEach((imdbID, index) => {
    const apiUrl = `http://www.omdbapi.com/?&apikey=${apiKey}&i=${imdbID}`;

    http.get(apiUrl, (response) => {
      let responseData = '';

      response.on('data', (chunk) => {
        responseData += chunk;
      });

      response.on('end', () => {
        try {
          const movieData = JSON.parse(responseData);

          if (movieData.Response === 'True') {
            const movie = {
              Released: movieData.Released !== 'N/A' ? new Date(movieData.Released).toISOString() : null,
              Runtime: movieData.Runtime !== 'N/A' ? parseInt(movieData.Runtime) : null,
              Genres: movieData.Genre ? movieData.Genre.split(',').map(genre => genre.trim()) : [],
              Directors: movieData.Director ? movieData.Director.split(',').map(director => director.trim()) : [],
              Writers: movieData.Writer ? movieData.Writer.split(',').map(writer => writer.trim()) : [],
              Actors: movieData.Actors ? movieData.Actors.split(',').map(actor => actor.trim()) : [],
              MetaScore: movieData.Metascore !== 'N/A' ? parseInt(movieData.Metascore) : null,
              imdbRating: movieData.imdbRating !== 'N/A' ? Number(movieData.imdbRating) : null,
            };
            movies.push(movie);
          } else {
            console.error(`Error retrieving movie with imdbID ${imdbID}: ${movieData.Error}`);
          }
        } catch (error) {
          console.error('Error parsing movie data:', error);
        } finally {
          completedRequests++;
          if (completedRequests === imdbIDs.length) {
            // 所有请求都已完成,发送响应
            res.status(200).send(movies);
          }
        }
      });
    }).on('error', (error) => {
      console.error('Error fetching movie data:', error);
      completedRequests++;
      if (completedRequests === imdbIDs.length) {
        // 即使有错误,也发送响应
        res.status(200).send(movies);
      }
    });
  });
});

app.listen(3000, () => {
  console.log('Server listening on port 3000');
});

关键改进:

  • 错误处理: 添加了更完善的错误处理机制,包括检查 imdbIDs 是否为数组,以及在API请求失败时记录错误信息。
  • 异步处理: 使用 completedRequests 变量来跟踪异步请求的完成情况,确保在所有 API 请求完成后再发送响应。
  • 数据清洗 对从 API 获取的数据进行清洗,确保 Released 字段能被正确转换为日期,并处理 N/A 值。
  • 空数组处理: 增加了对 imdbIDs 为空数组的特殊处理,避免不必要的API请求。
  • 简化响应发送: 所有情况下都确保最终会发送响应,避免请求hang住。

注意事项:

  • 替换 YOUR_API_KEY 为你实际的 OMDb API 密钥。
  • API密钥是敏感信息,不要将其暴露在客户端代码中。

前端 (index.js) 数据请求与处理

在前端,使用 XMLHttpRequest 或 fetch API 向 /movies 发送 POST 请求,并将选中的电影 ID 作为请求体发送。然后,处理服务器返回的电影数据,动态构建 HTML 元素。

RecoveryFox AI
RecoveryFox AI

AI驱动的数据恢复、文件恢复工具

下载
function loadMovies(imdbIDs) {
  const xhr = new XMLHttpRequest();
  xhr.open("POST", "/movies");
  xhr.setRequestHeader("Content-Type", "application/json"); // 设置请求头

  xhr.onload = function () {
    const mainElement = document.querySelector("main");

    // 清空 main 元素
    while (mainElement.firstChild) {
      mainElement.firstChild.remove();
    }

    if (xhr.status === 200) {
      try {
        const movies = JSON.parse(xhr.responseText);
        movies.forEach(movie => {
          // 使用 MovieBuilder 构建电影元素,并添加到 main 元素
          const movieElement = new MovieBuilder(movie, deleteMovie).build(); // 假设 MovieBuilder 有 build 方法
          mainElement.appendChild(movieElement);
        });
      } catch (error) {
        console.error("Error parsing JSON:", error);
        mainElement.textContent = "Error parsing movie data.";
      }
    } else {
      mainElement.textContent = `Data could not be loaded, status ${xhr.status} - ${xhr.statusText}`;
    }
  };

  xhr.onerror = function () {
    const mainElement = document.querySelector("main");
    mainElement.textContent = "Network error occurred.";
  };

  xhr.send(JSON.stringify(imdbIDs)); // 发送 JSON 字符串
}

// 示例:假设有一个表单,用户选择了一些电影的 imdbID
document.getElementById("movieForm").addEventListener("submit", function (event) {
  event.preventDefault(); // 阻止默认的表单提交

  const selectedMovies = [];
  const checkboxes = document.querySelectorAll('input[name="movie"]:checked'); // 假设checkbox的name是movie
  checkboxes.forEach(checkbox => {
    selectedMovies.push(checkbox.value); // 获取选中的 imdbID
  });

  loadMovies(selectedMovies); // 调用 loadMovies 函数,传递选中的 imdbID 数组
});

// 假设的 MovieBuilder 类 (需要根据你的实际代码调整)
class MovieBuilder {
  constructor(movie, deleteMovieCallback) {
    this.movie = movie;
    this.deleteMovieCallback = deleteMovieCallback;
  }

  build() {
    const movieElement = document.createElement('div');
    movieElement.classList.add('movie');

    // 添加电影信息到元素 (根据你的数据结构调整)
    const titleElement = document.createElement('h2');
    titleElement.textContent = this.movie.Title || 'Untitled';
    movieElement.appendChild(titleElement);

    const releasedElement = document.createElement('p');
    releasedElement.textContent = `Released: ${this.movie.Released || 'N/A'}`;
    movieElement.appendChild(releasedElement);

    // 其他电影信息的添加...

    return movieElement;
  }
}

关键改进:

  • POST 请求: 使用 xhr.open("POST", "/movies") 发送 POST 请求。
  • 设置请求头: 使用 xhr.setRequestHeader("Content-Type", "application/json") 设置请求头,告诉服务器发送的是 JSON 数据。
  • 发送 JSON 数据: 使用 xhr.send(JSON.stringify(imdbIDs)) 将 imdbIDs 数组转换为 JSON 字符串并发送。
  • 错误处理: 添加了 onerror 事件处理函数,处理网络错误。
  • JSON 解析错误处理: 在 onload 事件处理函数中,添加了 try...catch 块,处理 JSON 解析错误。
  • 动态构建 HTML: 使用 MovieBuilder 类动态构建 HTML 元素,并添加到 main 元素中。
  • 表单提交处理: 添加了表单提交事件处理函数,获取选中的电影 ID,并调用 loadMovies 函数。

注意事项:

  • 确保 HTML 中有一个 main 元素,用于显示电影信息。
  • 根据你的实际数据结构和 HTML 结构,调整 MovieBuilder 类的代码。
  • 根据你的实际需求,调整表单提交事件处理函数的代码。
  • 确保你的服务器端代码能够处理 Content-Type: application/json 的请求。

总结

本教程详细介绍了如何使用 Node.js/Express 处理 POST 请求,并将数据传递到另一个函数中进行处理。通过合理地组织代码,并注意错误处理和异步处理,可以构建一个高效且稳定的应用。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

178

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

215

2025.12.18

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

419

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

535

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

77

2025.09.10

ajax教程
ajax教程

php中文网为大家带来ajax教程合集,Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。php中文网还为大家带来ajax的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

159

2023.06.14

ajax中文乱码解决方法
ajax中文乱码解决方法

ajax中文乱码解决方法有设置请求头部的字符编码、在服务器端设置响应头部的字符编码和使用encodeURIComponent对中文进行编码。本专题为大家提供ajax中文乱码相关的文章、下载、课程内容,供大家免费下载体验。

160

2023.08.31

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

AngularJS教程
AngularJS教程

共24课时 | 3.1万人学习

CSS教程
CSS教程

共754课时 | 24.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号