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

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

npmのダウンロードトレンド
3 年
GitHub Starsランキング
統計詳細
パッケージ
ダウンロード数
Stars
サイズ
Issues
公開日時
ライセンス
form-data108,034,9302,34181.2 kB13617日前MIT
busboy18,449,2412,973124 kB36--
formidable14,179,344-204 kB-7ヶ月前MIT
multer8,721,71111,95729.5 kB2465ヶ月前MIT
express-fileupload401,0691,558119 kB225ヶ月前MIT
機能比較: form-data vs busboy vs formidable vs multer vs express-fileupload

ストリーミング処理

  • form-data:

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

  • busboy:

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

  • formidable:

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

  • multer:

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

  • express-fileupload:

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

使いやすさ

  • form-data:

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

  • busboy:

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

  • formidable:

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

  • multer:

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

  • express-fileupload:

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

ファイルサイズ制限

  • form-data:

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

  • busboy:

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

  • formidable:

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

  • multer:

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

  • express-fileupload:

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

エラーハンドリング

  • form-data:

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

  • busboy:

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

  • formidable:

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

  • multer:

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

  • express-fileupload:

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

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

  • form-data:

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

  • busboy:

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

  • formidable:

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

  • multer:

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

  • express-fileupload:

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

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

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

  • busboy:

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

  • formidable:

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

  • multer:

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

  • express-fileupload:

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

form-data のREADME

Form-Data NPM Module Join the chat at https://gitter.im/form-data/form-data

A library to create readable "multipart/form-data" streams. Can be used to submit forms and file uploads to other web applications.

The API of this library is inspired by the XMLHttpRequest-2 FormData Interface.

Linux Build MacOS Build Windows Build

Coverage Status Dependency Status

Install

npm install --save form-data

Usage

In this example we are constructing a form with 3 fields that contain a string, a buffer and a file stream.

var FormData = require('form-data');
var fs = require('fs');

var form = new FormData();
form.append('my_field', 'my value');
form.append('my_buffer', new Buffer(10));
form.append('my_file', fs.createReadStream('/foo/bar.jpg'));

Also you can use http-response stream:

var FormData = require('form-data');
var http = require('http');

var form = new FormData();

http.request('http://nodejs.org/images/logo.png', function (response) {
  form.append('my_field', 'my value');
  form.append('my_buffer', new Buffer(10));
  form.append('my_logo', response);
});

Or @mikeal's request stream:

var FormData = require('form-data');
var request = require('request');

var form = new FormData();

form.append('my_field', 'my value');
form.append('my_buffer', new Buffer(10));
form.append('my_logo', request('http://nodejs.org/images/logo.png'));

In order to submit this form to a web application, call submit(url, [callback]) method:

form.submit('http://example.org/', function (err, res) {
  // res – response object (http.IncomingMessage)  //
  res.resume();
});

For more advanced request manipulations submit() method returns http.ClientRequest object, or you can choose from one of the alternative submission methods.

Custom options

You can provide custom options, such as maxDataSize:

var FormData = require('form-data');

var form = new FormData({ maxDataSize: 20971520 });
form.append('my_field', 'my value');
form.append('my_buffer', /* something big */);

List of available options could be found in combined-stream

Alternative submission methods

You can use node's http client interface:

var http = require('http');

var request = http.request({
  method: 'post',
  host: 'example.org',
  path: '/upload',
  headers: form.getHeaders()
});

form.pipe(request);

request.on('response', function (res) {
  console.log(res.statusCode);
});

Or if you would prefer the 'Content-Length' header to be set for you:

form.submit('example.org/upload', function (err, res) {
  console.log(res.statusCode);
});

To use custom headers and pre-known length in parts:

var CRLF = '\r\n';
var form = new FormData();

var options = {
  header: CRLF + '--' + form.getBoundary() + CRLF + 'X-Custom-Header: 123' + CRLF + CRLF,
  knownLength: 1
};

form.append('my_buffer', buffer, options);

form.submit('http://example.com/', function (err, res) {
  if (err) throw err;
  console.log('Done');
});

Form-Data can recognize and fetch all the required information from common types of streams (fs.readStream, http.response and mikeal's request), for some other types of streams you'd need to provide "file"-related information manually:

someModule.stream(function (err, stdout, stderr) {
  if (err) throw err;

  var form = new FormData();

  form.append('file', stdout, {
    filename: 'unicycle.jpg', // ... or:
    filepath: 'photos/toys/unicycle.jpg',
    contentType: 'image/jpeg',
    knownLength: 19806
  });

  form.submit('http://example.com/', function (err, res) {
    if (err) throw err;
    console.log('Done');
  });
});

The filepath property overrides filename and may contain a relative path. This is typically used when uploading multiple files from a directory.

For edge cases, like POST request to URL with query string or to pass HTTP auth credentials, object can be passed to form.submit() as first parameter:

form.submit({
  host: 'example.com',
  path: '/probably.php?extra=params',
  auth: 'username:password'
}, function (err, res) {
  console.log(res.statusCode);
});

In case you need to also send custom HTTP headers with the POST request, you can use the headers key in first parameter of form.submit():

form.submit({
  host: 'example.com',
  path: '/surelynot.php',
  headers: { 'x-test-header': 'test-header-value' }
}, function (err, res) {
  console.log(res.statusCode);
});

Methods

Void append( String field, Mixed value [, Mixed options] )

Append data to the form. You can submit about any format (string, integer, boolean, buffer, etc.). However, Arrays are not supported and need to be turned into strings by the user.

var form = new FormData();
form.append('my_string', 'my value');
form.append('my_integer', 1);
form.append('my_boolean', true);
form.append('my_buffer', new Buffer(10));
form.append('my_array_as_json', JSON.stringify(['bird', 'cute']));

You may provide a string for options, or an object.

// Set filename by providing a string for options
form.append('my_file', fs.createReadStream('/foo/bar.jpg'), 'bar.jpg');

// provide an object.
form.append('my_file', fs.createReadStream('/foo/bar.jpg'), { filename: 'bar.jpg', contentType: 'image/jpeg', knownLength: 19806 });

Headers getHeaders( [Headers userHeaders] )

This method adds the correct content-type header to the provided array of userHeaders.

String getBoundary()

Return the boundary of the formData. By default, the boundary consists of 26 - followed by 24 numbers for example:

--------------------------515890814546601021194782

Void setBoundary(String boundary)

Set the boundary string, overriding the default behavior described above.

Note: The boundary must be unique and may not appear in the data.

Buffer getBuffer()

Return the full formdata request package, as a Buffer. You can insert this Buffer in e.g. Axios to send multipart data.

var form = new FormData();
form.append('my_buffer', Buffer.from([0x4a,0x42,0x20,0x52,0x6f,0x63,0x6b,0x73]));
form.append('my_file', fs.readFileSync('/foo/bar.jpg'));

axios.post('https://example.com/path/to/api', form.getBuffer(), form.getHeaders());

Note: Because the output is of type Buffer, you can only append types that are accepted by Buffer: string, Buffer, ArrayBuffer, Array, or Array-like Object. A ReadStream for example will result in an error.

Integer getLengthSync()

Same as getLength but synchronous.

Note: getLengthSync doesn't calculate streams length.

Integer getLength(function callback )

Returns the Content-Length async. The callback is used to handle errors and continue once the length has been calculated

this.getLength(function (err, length) {
  if (err) {
    this._error(err);
    return;
  }

  // add content length
  request.setHeader('Content-Length', length);

  ...
}.bind(this));

Boolean hasKnownLength()

Checks if the length of added values is known.

Request submit(params, function callback )

Submit the form to a web application.

var form = new FormData();
form.append('my_string', 'Hello World');

form.submit('http://example.com/', function (err, res) {
  // res – response object (http.IncomingMessage)  //
  res.resume();
} );

String toString()

Returns the form data as a string. Don't use this if you are sending files or buffers, use getBuffer() instead.

Integration with other libraries

Request

Form submission using request:

var formData = {
  my_field: 'my_value',
  my_file: fs.createReadStream(__dirname + '/unicycle.jpg'),
};

request.post({url:'http://service.com/upload', formData: formData}, function (err, httpResponse, body) {
  if (err) {
    return console.error('upload failed:', err);
  }
  console.log('Upload successful!  Server responded with:', body);
});

For more details see request readme.

node-fetch

You can also submit a form using node-fetch:

var form = new FormData();

form.append('a', 1);

fetch('http://example.com', { method: 'POST', body: form })
    .then(function (res) {
        return res.json();
    }).then(function (json) {
        console.log(json);
    });

axios

In Node.js you can post a file using axios:

const form = new FormData();
const stream = fs.createReadStream(PATH_TO_FILE);

form.append('image', stream);

// In Node.js environment you need to set boundary in the header field 'Content-Type' by calling method `getHeaders`
const formHeaders = form.getHeaders();

axios.post('http://example.com', form, {
  headers: {
    ...formHeaders,
  },
})
  .then(response => response)
  .catch(error => error)

Notes

  • getLengthSync() method DOESN'T calculate length for streams, use knownLength options as workaround.
  • getLength(cb) will send an error as first parameter of callback if stream length cannot be calculated (e.g. send in custom streams w/o using knownLength).
  • submit will not add content-length if form length is unknown or not calculable.
  • Starting version 2.x FormData has dropped support for node@0.10.x.
  • Starting version 3.x FormData has dropped support for node@4.x.

License

Form-Data is released under the MIT license.