
本文介绍了如何在 Node.js/Express 应用中接收 POST 请求发送的数据,并将其传递到另一个函数进行进一步处理。重点在于确保请求方法匹配,并正确地在客户端和服务器端处理数据传输。文章将提供示例代码,帮助你理解如何实现数据的接收、传递和使用。
在 Node.js/Express 应用中,处理 POST 请求并将其数据传递到另一个函数,需要理解以下几个关键步骤:
以下是一个示例,展示了如何在 server.js 文件中接收 POST 请求,并处理数据:
const express = require('express');
const bodyParser = require('body-parser');
const http = require('http');
const app = express();
const port = 3000;
// 使用 body-parser 中间件解析请求体
app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json());
app.post("/movies", function (req, res) {
const imdbIDs = req.body;
if (!Array.isArray(imdbIDs)) {
res.status(400).send('Invalid input. Expected an array of imdbIDs.');
return;
}
const apiKEY = 'YOUR_API_KEY'; // 替换为你的 API 密钥
const movies = [];
let completedRequests = 0;
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).json(movies);
}
}
});
}).on('error', (error) => {
console.error('Error fetching movie data:', error);
completedRequests++;
if (completedRequests === imdbIDs.length) {
// 即使有错误,也在所有请求完成后发送响应
res.status(200).json(movies);
}
});
});
});
app.listen(port, () => {
console.log(`Server listening at http://localhost:${port}`);
});代码解释:
CA.LA
第一款时尚产品在线设计平台,服装设计系统
86
查看详情
以下是一个示例,展示了如何在 index.js 文件中发送 POST 请求,并处理服务器的响应:
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");
while (mainElement.childElementCount > 0) {
mainElement.firstChild.remove()
}
if (xhr.status === 200) {
JSON.parse(xhr.responseText)
.forEach(movie => {
// 这里可以调用 MovieBuilder,或者直接操作 DOM
console.log(movie); // 打印接收到的电影数据
//new MovieBuilder(movie, deleteMovie).appendTo(mainElement)
});
} else {
mainElement.append(`Data could not be loaded, status ${xhr.status} - ${xhr.statusText}`);
}
}
xhr.onerror = function() {
console.error("Request failed");
}
xhr.send(JSON.stringify(imdbIDs)); // 将数据转换为 JSON 字符串并发送
}
// 示例调用
const movieIds = ["tt0076759", "tt0080684", "tt0086190"]; // 示例 IMDB ID
loadMovies(movieIds);代码解释:
通过本文,你应该能够理解如何在 Node.js/Express 应用中接收 POST 请求发送的数据,并将其传递到另一个函数进行进一步处理。 关键在于正确设置请求方法和 Content-Type,以及使用 body-parser 中间件来解析请求体。 此外,良好的错误处理和异步处理也是必不可少的。 记住,客户端和服务端都需要正确地处理数据格式,才能保证数据传输的正确性。
以上就是在 Node.js/Express 中处理 POST 请求数据并在另一函数中使用的详细内容,更多请关注其它相关文章!
# 如何在
# 宁波网站建设收费多少
# 嘉文全网营销推广怎么样
# seo怎么优化九步曲
# 公司形象网站建设制作
# 平房网站关键词排名
# 苏州二级目录seo
# 网站营销怎么推广计划
# 随县SEO
# 百度怎么seo
# 苏州网站推广公司托管
# 并将其
# 正确地
# 转换为
# 完成后
# 数据处理
# javascript
# 是一个
# 并在
# 回调
# 客户端
# 字符串解析
# 路由
# ai
# 回调函数
# app
# node
# json
# node.js
# js
# java
相关栏目:
【
Google疑问12 】
【
Facebook疑问10 】
【
优化推广96088 】
【
技术知识133117 】
【
IDC资讯59369 】
【
网络运营7196 】
【
IT资讯61894 】
相关推荐:
深入理解Python对象引用与链表属性赋值
263企业邮箱如何设置邮件转发功能
mysql归档数据怎么导出为csv_mysql归档数据导出为csv文件的方法
《波斯王子:失落的王冠》剑术大师打法攻略
cad视图选项卡不见了怎么办_cad视图标签恢复显示方法
高德地图导航路线偏差报警频繁怎么办 高德地图路线偏差修复与优化方法
Final Cut Pro视频加EQ教程
《雷电模拟器》自动点击设置方法
RxJS中如何高效地在一个函数内处理和合并多个数据集合
韩小圈网页版PC端入口 韩小圈网页版官方网站入口
在Peewee中处理PostgreSQL记录重复:一站式数据摄取教程
漫蛙manwa漫画官网链接_漫蛙manwa最新可用网址推荐
iPhone14无法连接蓝牙设备如何解决
J*a中导出MySQL表为SQL脚本的两种方法
《盗墓笔记手游》技能介绍
ao3入口镜像地址 ao3镜像入口可靠跳转
VS Code快捷键when上下文子句的妙用
铁路12306座位怎么选_12306官方选座操作方法
微信如何设置字体大小_微信字体设置的阅读舒适
Win10截图远程协助 Win10远程桌面截屏法【场景应用】
在J*a中如何实现类的继承与方法重用_OOP继承方法重用技巧分享
如何配置VS Code作为您Git操作的默认编辑器
智学网成绩单查询系统网_智学网学生平台登录
抖音官网入口快速访问 抖音网页版账号注册解析
React应用中Commerce.js数据加载与状态管理最佳实践
《虎扑》取消评分记录方法
谷歌邮箱官方入口链接 谷歌邮箱网页版电脑端快速登录
抖音怎么解除第三方绑定_抖音解除第三方平台绑定方法介绍
优化 WooCommerce 产品价格显示与自定义短代码集成
智学网app怎么登录忘记密码_智学网app忘记密码找回与重新登录操作方法
偃武诸葛亮阵容搭配推荐
之了课堂app做题入口
Fedora怎么安装 Fedora Workstation安装步骤
谷歌浏览器官网地址整理_谷歌浏览器新版直连2026稳定访问
包子漫画官网链接官方地址 包子漫画在线观看官网首页入口
firefox火狐浏览器最新官网主页_ firefox火狐浏览器平台入口直达官方链接
J*a中为什么强调组合优于继承_组合模式带来的灵活性与可维护性解析
win11资源管理器标签页怎么用 Win11文件管理器多标签高效操作【新功能】
cad怎么隐藏指定的图层_cad隐藏或冻结图层方法
解决 Vue 3 组件未定义错误:理解 createApp 与根组件的正确使用
抖音赚钱快速入门_新手必看的抖音赚钱步骤
《桃源记2》资源采集攻略
抖音号升级成企业资质怎么弄?有什么好处?
如何查询国外邮政编码_国外邮政编码查询的多种有效途径
天堂漫画网页版在线阅读 天堂漫画手机版入口
《百果园》充值余额方法
Excel如何制作月度销售统计图_Excel动态图表制作与控件应用
PDF文件去水印平台入口 PDF水印删除网址
《海底捞》点外卖方法
Win11如何分屏操作_Win11多窗口分屏技巧
2025-10-08
运城市盐湖区信雨科技有限公司是一家深耕海外推广领域十年的专业服务商,作为谷歌推广与Facebook广告全球合作伙伴,聚焦外贸企业出海痛点,以数字化营销为核心,提供一站式海外营销解决方案。公司凭借十年行业沉淀与平台官方资源加持,打破传统外贸获客壁垒,助力企业高效开拓全球市场,成为中小企业出海的可靠合作伙伴。