深入了解request獲取body內容的多個方面

一、獲取body內容的基本概念

當我們使用HTTP協議發送POST請求時,需要向服務器傳遞一些數據,這些數據保存在body中。常見的有form表單、JSON數據等形式。接受此類請求時需要使用request獲取body內容,對於不同的數據形式,獲取方式是不同的。

二、獲取form表單數據

form表單數據是最常見的請求數據之一。對於Node.js中的request對象,獲取form表單數據需要使用模塊querystring解析。

const http = require('http');
const querystring = require('querystring');

http.createServer((req, res) => {
  if(req.method === 'POST') {
    let body = '';
    req.on('data', data => {
      body += data.toString();
    });
    req.on('end', () => {
      const requestBody = querystring.parse(body);
      console.log(requestBody);
      res.end('success');
    })
  }
}).listen(3000);

需要注意的是,獲取到的requestBody是一個對象,需要使用JSON.stringify()將其轉換成JSON格式的字符串。

三、獲取JSON數據

對於包含JSON數據的POST請求,使用Node.js的request對象獲取數據需要使用內置模塊querystring和JSON模塊配合使用。

const http = require('http');

http.createServer((req, res) => {
  if(req.method === 'POST') {
    let body = '';
    req.on('data', data => {
      body += data.toString();
    });
    req.on('end', () => {
      const requestBody = JSON.parse(body);
      console.log(requestBody);
      res.end('success');
    })
  }
}).listen(3000);

四、獲取文件上傳數據

對於文件上傳類的POST請求,需要使用npm上的第三方模塊formidable來解析請求中的form表單和文件數據。

const http = require('http');
const formidable = require('formidable');

http.createServer((req, res) => {
  if(req.url === '/upload' && req.method.toLowerCase() === 'post') {
    const form = formidable({ multiples: true });
    form.parse(req, (err, fields, files) => {
      if(err) {
        console.error(err);
        return;
      }
      console.log(files);
      res.writeHead(200, {'content-type': 'text/plain'});
      res.write('received upload:\n\n');
      res.end('success');
    });
    return;
  }
}).listen(3000);

需要注意的是,formidable模塊解析請求時,需要在formidable對象中傳遞一個mulitples屬性,值為true。這是因為formidable默認處理單文件上傳請求,當處理多個文件上傳請求時需要設置此屬性。

五、獲取流數據

對於更加高級的POST請求,包含stream數據時,則需要使用Node.js中的Stream對象獲取數據。

const http = require('http');

http.createServer((req, res) => {
  if(req.method === 'POST') {
    let body = [];
    req.on('data', chunk => {
      body.push(chunk);
    });
    req.on('end', () => {
      body = Buffer.concat(body).toString();
      console.log(body);
      res.end('success');
    });
  }
}).listen(3000);

在Stream對象中,我們可以使用請求的event事件偵聽器來逐步獲取數據,最後合成一個完整的數據流。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/227826.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-09 21:21
下一篇 2024-12-09 21:21

相關推薦

發表回復

登錄後才能評論