node服务器——处理原始的请求流

javascript 复制代码
const express = require('express');
const fs = require('fs');
const app = express();
const port = 3333;

app.post('/', (req, res) => {
  const chunks = []; // 用来存储请求体的数据块  

  req.on('data', (chunk) => {
    chunks.push(chunk); // 将接收到的数据块添加到数组中  
  });

  req.on('end', () => {
    const body = Buffer.concat(chunks); // 将数据块拼接成完整的请求体  
    const filePath = './raw_request_body.txt'; // 文件路径  

    fs.writeFile(filePath, body, (err) => {
      if (err) {
        console.error('Error writing to file:', err);
        return res.status(500).send('Error writing to file');
      }
      console.log('Raw request body written to file successfully');
      res.send('Raw request body received and written to file');
    });
  });
});

app.listen(port, () => {
  console.log(`Server is running on port ${port}`);
});

1、监听req对象的**data**事件来接收请求体的数据块,并将它们存储在一个数组中。

2、当请求结束时(即end事件触发时),我们使用Buffer.concat将数组中的所有数据块拼接成一个完整的Buffer对象,然后将其写入到文件中。

请注意,这种方法仅适用于请求体不是非常大的情况,因为整个请求体都会存储在内存中。如果请求体非常大,您可能需要使用流来逐步写入文件,以避免内存不足的问题。

此外,如果您还想记录请求的其他信息(如头部、URL等),您可以像之前那样直接访问req.headersreq.url等属性,并将它们以您喜欢的方式写入文件。

result:

{"phone":"123412342134"}

注意:此处的body是Buffer类型,如果想要转换为对象类型,需要以下几步:

javascript 复制代码
  let body = Buffer.concat(chunks); // 将数据块拼接成完整的请求体  

  body = body.toString('utf8'); // 转换为字符串类型 - JSON类型(因为数据本来就是json格式的)

  body = JSON.parse(body); // 将JSON类型(json字符串)转换为对象类型

  console.log(body);
相关推荐
霜落花轻扬7 小时前
在 Rails 中指定端口和 IP 地址
服务器·ruby on rails
H Journey7 小时前
网络编程:服务器监听+非阻塞设置
服务器·网络·服务器监听+非阻塞设置
学困昇8 小时前
彻底搞懂 Linux 基础 IO:文件描述符、重定向、dup2、缓冲区一次讲透!
linux·运维·服务器·开发语言·c++
赋创小助手8 小时前
PCIe 8.0 要来了:1TB/s 带宽背后,AI 算力服务器正在进入“高速互联时代”
运维·服务器·人工智能
yyuuuzz8 小时前
国际云服务商运维常见问题梳理
运维·服务器·网络·github·aws
是谁眉眼9 小时前
npm执行错误 但黑窗口node可以成功启动问题分析
前端·npm·node.js
焦糖玛奇朵婷9 小时前
终于搞清楚了,扭蛋机小程序这么厉害❗
java·服务器·前端·程序人生·小程序
量子炒饭大师9 小时前
【Linux系统编程】Cyberpunk在霓虹丛林中构建堡垒 —— 【关于 root 超级管理员权限】
linux·运维·服务器·root·uid
donecoding9 小时前
Monorepo 里有 app 也有共享包,lerna 真的还需要吗?
前端·node.js·前端工程化
leaves falling9 小时前
Linux基础开发工具详解:从yum到gdb的完整指南
linux·运维·服务器