busboy vs express-fileupload vs form-data vs formidable vs multer
ファイルアップロードライブラリ
busboyexpress-fileuploadform-dataformidablemulter類似パッケージ:

ファイルアップロードライブラリ

ファイルアップロードライブラリは、Node.jsアプリケーションにおいて、ユーザーがサーバーにファイルをアップロードする際の処理を簡素化するためのツールです。これらのライブラリは、HTTPリクエストからファイルを解析し、適切に処理するための機能を提供します。これにより、開発者はファイルの受信、検証、保存を効率的に行うことができます。

npmのダウンロードトレンド

3 年

GitHub Starsランキング

統計詳細

パッケージ
ダウンロード数
Stars
サイズ
Issues
公開日時
ライセンス
busboy28,248,5962,996124 kB37--
express-fileupload502,4741,561119 kB248ヶ月前MIT
form-data02,35681.2 kB1373ヶ月前MIT
formidable0-204 kB-10ヶ月前MIT
multer012,00429.5 kB2477ヶ月前MIT

機能比較: busboy vs express-fileupload vs form-data vs formidable vs multer

ストリーミング処理

  • busboy:

    Busboyはストリームを利用したファイル処理を行い、大きなファイルをメモリに負担をかけずに処理できます。これにより、リアルタイムでのファイル処理が可能です。

  • express-fileupload:

    express-fileuploadは、ストリーミング処理をサポートしていませんが、簡単なファイルアップロードには十分な機能を提供します。

  • form-data:

    form-dataは主にリクエストを作成するためのライブラリであり、ストリーミング処理には対応していません。

  • formidable:

    Formidableはストリーミング処理をサポートしており、大きなファイルを効率的に処理できます。

  • multer:

    Multerは、ストリーミング処理を行わず、ファイルをメモリまたはディスクに保存するためのシンプルな方法を提供します。

使いやすさ

  • busboy:

    Busboyはストリームベースのため、少し複雑なAPIを持っていますが、効率的なファイル処理が可能です。

  • express-fileupload:

    express-fileuploadは非常にシンプルなAPIを持ち、すぐに使い始めることができます。

  • form-data:

    form-dataはHTTPリクエストを作成するためのライブラリで、使い方は比較的簡単ですが、ファイルアップロード専用ではありません。

  • formidable:

    Formidableは多機能ですが、設定が多く、初心者には少し難しいかもしれません。

  • multer:

    MulterはExpress.jsと統合されているため、使いやすく、すぐに実装できます。

ファイルサイズ制限

  • busboy:

    Busboyは、ファイルサイズ制限を簡単に設定でき、大きなファイルの処理に適しています。

  • express-fileupload:

    express-fileuploadは、ファイルサイズ制限を設定するオプションがありますが、デフォルトでは制限がありません。

  • form-data:

    form-dataは、ファイルサイズ制限を設定する機能を持っていません。

  • formidable:

    Formidableは、ファイルサイズ制限を設定でき、特に大きなファイルを扱う際に便利です。

  • multer:

    Multerは、ファイルサイズ制限を簡単に設定でき、特定のサイズを超えるファイルを拒否することができます。

エラーハンドリング

  • busboy:

    Busboyは、ストリーミング中にエラーが発生した場合、適切なエラーハンドリングを提供します。

  • express-fileupload:

    express-fileuploadは、エラーが発生した場合のハンドリングが簡単で、ユーザーにわかりやすいエラーメッセージを返すことができます。

  • form-data:

    form-dataは、エラーハンドリングの機能が限られており、主にリクエストの作成に使用されます。

  • formidable:

    Formidableは、詳細なエラーハンドリング機能を持ち、エラーの原因を特定しやすくなっています。

  • multer:

    Multerは、ファイルアップロード中のエラーを簡単に捕捉でき、適切なエラーメッセージを返すことができます。

サポートされるファイルタイプ

  • busboy:

    Busboyは、任意のファイルタイプを処理でき、特に大きなファイルに適しています。

  • express-fileupload:

    express-fileuploadは、一般的なファイルタイプをサポートしており、特に画像ファイルのアップロードに適しています。

  • form-data:

    form-dataは、ファイルタイプに制限がなく、任意のファイルを送信できます。

  • formidable:

    Formidableは、さまざまなファイルタイプをサポートしており、特に大きなファイルのアップロードに適しています。

  • multer:

    Multerは、特定のファイルタイプを制限することができ、セキュリティの観点からも優れています。

選び方: busboy vs express-fileupload vs form-data vs formidable vs multer

  • busboy:

    Busboyはストリームベースのライブラリで、大きなファイルを効率的に処理する必要がある場合に最適です。ストリーミング処理により、メモリ使用量を抑えつつ、リアルタイムでファイルを処理できます。

  • express-fileupload:

    Express-fileuploadは、Expressフレームワークと統合されており、シンプルなAPIを提供します。小規模なプロジェクトや、簡単なファイルアップロード機能が必要な場合に適しています。

  • form-data:

    Form-dataは、HTTPリクエストを作成するためのライブラリで、特にAPIとの通信においてファイルを送信する際に便利です。クライアントサイドでの使用が主で、サーバーサイドではあまり使われません。

  • formidable:

    Formidableは、ファイルアップロードの処理に特化したライブラリで、複雑なファイルアップロード機能を必要とする場合に適しています。多くのオプションと設定が可能で、柔軟性があります。

  • multer:

    Multerは、Express.jsのミドルウェアとして動作し、ファイルのアップロードを簡単に処理できます。特に、フォームからのファイルアップロードを簡単に実装したい場合に適しています。

busboy のREADME

Description

A node.js module for parsing incoming HTML form data.

Changes (breaking or otherwise) in v1.0.0 can be found here.

Requirements

Install

npm install busboy

Examples

  • Parsing (multipart) with default options:
const http = require('http');

const busboy = require('busboy');

http.createServer((req, res) => {
  if (req.method === 'POST') {
    console.log('POST request');
    const bb = busboy({ headers: req.headers });
    bb.on('file', (name, file, info) => {
      const { filename, encoding, mimeType } = info;
      console.log(
        `File [${name}]: filename: %j, encoding: %j, mimeType: %j`,
        filename,
        encoding,
        mimeType
      );
      file.on('data', (data) => {
        console.log(`File [${name}] got ${data.length} bytes`);
      }).on('close', () => {
        console.log(`File [${name}] done`);
      });
    });
    bb.on('field', (name, val, info) => {
      console.log(`Field [${name}]: value: %j`, val);
    });
    bb.on('close', () => {
      console.log('Done parsing form!');
      res.writeHead(303, { Connection: 'close', Location: '/' });
      res.end();
    });
    req.pipe(bb);
  } else if (req.method === 'GET') {
    res.writeHead(200, { Connection: 'close' });
    res.end(`
      <html>
        <head></head>
        <body>
          <form method="POST" enctype="multipart/form-data">
            <input type="file" name="filefield"><br />
            <input type="text" name="textfield"><br />
            <input type="submit">
          </form>
        </body>
      </html>
    `);
  }
}).listen(8000, () => {
  console.log('Listening for requests');
});

// Example output:
//
// Listening for requests
//   < ... form submitted ... >
// POST request
// File [filefield]: filename: "logo.jpg", encoding: "binary", mime: "image/jpeg"
// File [filefield] got 11912 bytes
// Field [textfield]: value: "testing! :-)"
// File [filefield] done
// Done parsing form!
  • Save all incoming files to disk:
const { randomFillSync } = require('crypto');
const fs = require('fs');
const http = require('http');
const os = require('os');
const path = require('path');

const busboy = require('busboy');

const random = (() => {
  const buf = Buffer.alloc(16);
  return () => randomFillSync(buf).toString('hex');
})();

http.createServer((req, res) => {
  if (req.method === 'POST') {
    const bb = busboy({ headers: req.headers });
    bb.on('file', (name, file, info) => {
      const saveTo = path.join(os.tmpdir(), `busboy-upload-${random()}`);
      file.pipe(fs.createWriteStream(saveTo));
    });
    bb.on('close', () => {
      res.writeHead(200, { 'Connection': 'close' });
      res.end(`That's all folks!`);
    });
    req.pipe(bb);
    return;
  }
  res.writeHead(404);
  res.end();
}).listen(8000, () => {
  console.log('Listening for requests');
});

API

Exports

busboy exports a single function:

( function )(< object >config) - Creates and returns a new Writable form parser stream.

  • Valid config properties:

    • headers - object - These are the HTTP headers of the incoming request, which are used by individual parsers.

    • highWaterMark - integer - highWaterMark to use for the parser stream. Default: node's stream.Writable default.

    • fileHwm - integer - highWaterMark to use for individual file streams. Default: node's stream.Readable default.

    • defCharset - string - Default character set to use when one isn't defined. Default: 'utf8'.

    • defParamCharset - string - For multipart forms, the default character set to use for values of part header parameters (e.g. filename) that are not extended parameters (that contain an explicit charset). Default: 'latin1'.

    • preservePath - boolean - If paths in filenames from file parts in a 'multipart/form-data' request shall be preserved. Default: false.

    • limits - object - Various limits on incoming data. Valid properties are:

      • fieldNameSize - integer - Max field name size (in bytes). Default: 100.

      • fieldSize - integer - Max field value size (in bytes). Default: 1048576 (1MB).

      • fields - integer - Max number of non-file fields. Default: Infinity.

      • fileSize - integer - For multipart forms, the max file size (in bytes). Default: Infinity.

      • files - integer - For multipart forms, the max number of file fields. Default: Infinity.

      • parts - integer - For multipart forms, the max number of parts (fields + files). Default: Infinity.

      • headerPairs - integer - For multipart forms, the max number of header key-value pairs to parse. Default: 2000 (same as node's http module).

This function can throw exceptions if there is something wrong with the values in config. For example, if the Content-Type in headers is missing entirely, is not a supported type, or is missing the boundary for 'multipart/form-data' requests.

(Special) Parser stream events

  • file(< string >name, < Readable >stream, < object >info) - Emitted for each new file found. name contains the form field name. stream is a Readable stream containing the file's data. No transformations/conversions (e.g. base64 to raw binary) are done on the file's data. info contains the following properties:

    • filename - string - If supplied, this contains the file's filename. WARNING: You should almost never use this value as-is (especially if you are using preservePath: true in your config) as it could contain malicious input. You are better off generating your own (safe) filenames, or at the very least using a hash of the filename.

    • encoding - string - The file's 'Content-Transfer-Encoding' value.

    • mimeType - string - The file's 'Content-Type' value.

    Note: If you listen for this event, you should always consume the stream whether you care about its contents or not (you can simply do stream.resume(); if you want to discard/skip the contents), otherwise the 'finish'/'close' event will never fire on the busboy parser stream. However, if you aren't accepting files, you can either simply not listen for the 'file' event at all or set limits.files to 0, and any/all files will be automatically skipped (these skipped files will still count towards any configured limits.files and limits.parts limits though).

    Note: If a configured limits.fileSize limit was reached for a file, stream will both have a boolean property truncated set to true (best checked at the end of the stream) and emit a 'limit' event to notify you when this happens.

  • field(< string >name, < string >value, < object >info) - Emitted for each new non-file field found. name contains the form field name. value contains the string value of the field. info contains the following properties:

    • nameTruncated - boolean - Whether name was truncated or not (due to a configured limits.fieldNameSize limit)

    • valueTruncated - boolean - Whether value was truncated or not (due to a configured limits.fieldSize limit)

    • encoding - string - The field's 'Content-Transfer-Encoding' value.

    • mimeType - string - The field's 'Content-Type' value.

  • partsLimit() - Emitted when the configured limits.parts limit has been reached. No more 'file' or 'field' events will be emitted.

  • filesLimit() - Emitted when the configured limits.files limit has been reached. No more 'file' events will be emitted.

  • fieldsLimit() - Emitted when the configured limits.fields limit has been reached. No more 'field' events will be emitted.