twitst4tz

twitter statistics web application
Log | Files | Refs | README | LICENSE

README.md (7138B)


      1 # Form-Data [![NPM Module](https://img.shields.io/npm/v/form-data.svg)](https://www.npmjs.com/package/form-data) [![Join the chat at https://gitter.im/form-data/form-data](http://form-data.github.io/images/gitterbadge.svg)](https://gitter.im/form-data/form-data)
      2 
      3 A library to create readable ```"multipart/form-data"``` streams. Can be used to submit forms and file uploads to other web applications.
      4 
      5 The API of this library is inspired by the [XMLHttpRequest-2 FormData Interface][xhr2-fd].
      6 
      7 [xhr2-fd]: http://dev.w3.org/2006/webapi/XMLHttpRequest-2/Overview.html#the-formdata-interface
      8 
      9 [![Linux Build](https://img.shields.io/travis/form-data/form-data/v2.3.3.svg?label=linux:4.x-9.x)](https://travis-ci.org/form-data/form-data)
     10 [![MacOS Build](https://img.shields.io/travis/form-data/form-data/v2.3.3.svg?label=macos:4.x-9.x)](https://travis-ci.org/form-data/form-data)
     11 [![Windows Build](https://img.shields.io/appveyor/ci/alexindigo/form-data/v2.3.3.svg?label=windows:4.x-9.x)](https://ci.appveyor.com/project/alexindigo/form-data)
     12 
     13 [![Coverage Status](https://img.shields.io/coveralls/form-data/form-data/v2.3.3.svg?label=code+coverage)](https://coveralls.io/github/form-data/form-data?branch=master)
     14 [![Dependency Status](https://img.shields.io/david/form-data/form-data.svg)](https://david-dm.org/form-data/form-data)
     15 [![bitHound Overall Score](https://www.bithound.io/github/form-data/form-data/badges/score.svg)](https://www.bithound.io/github/form-data/form-data)
     16 
     17 ## Install
     18 
     19 ```
     20 npm install --save form-data
     21 ```
     22 
     23 ## Usage
     24 
     25 In this example we are constructing a form with 3 fields that contain a string,
     26 a buffer and a file stream.
     27 
     28 ``` javascript
     29 var FormData = require('form-data');
     30 var fs = require('fs');
     31 
     32 var form = new FormData();
     33 form.append('my_field', 'my value');
     34 form.append('my_buffer', new Buffer(10));
     35 form.append('my_file', fs.createReadStream('/foo/bar.jpg'));
     36 ```
     37 
     38 Also you can use http-response stream:
     39 
     40 ``` javascript
     41 var FormData = require('form-data');
     42 var http = require('http');
     43 
     44 var form = new FormData();
     45 
     46 http.request('http://nodejs.org/images/logo.png', function(response) {
     47   form.append('my_field', 'my value');
     48   form.append('my_buffer', new Buffer(10));
     49   form.append('my_logo', response);
     50 });
     51 ```
     52 
     53 Or @mikeal's [request](https://github.com/request/request) stream:
     54 
     55 ``` javascript
     56 var FormData = require('form-data');
     57 var request = require('request');
     58 
     59 var form = new FormData();
     60 
     61 form.append('my_field', 'my value');
     62 form.append('my_buffer', new Buffer(10));
     63 form.append('my_logo', request('http://nodejs.org/images/logo.png'));
     64 ```
     65 
     66 In order to submit this form to a web application, call ```submit(url, [callback])``` method:
     67 
     68 ``` javascript
     69 form.submit('http://example.org/', function(err, res) {
     70   // res – response object (http.IncomingMessage)  //
     71   res.resume();
     72 });
     73 
     74 ```
     75 
     76 For more advanced request manipulations ```submit()``` method returns ```http.ClientRequest``` object, or you can choose from one of the alternative submission methods.
     77 
     78 ### Custom options
     79 
     80 You can provide custom options, such as `maxDataSize`:
     81 
     82 ``` javascript
     83 var FormData = require('form-data');
     84 
     85 var form = new FormData({ maxDataSize: 20971520 });
     86 form.append('my_field', 'my value');
     87 form.append('my_buffer', /* something big */);
     88 ```
     89 
     90 List of available options could be found in [combined-stream](https://github.com/felixge/node-combined-stream/blob/master/lib/combined_stream.js#L7-L15)
     91 
     92 ### Alternative submission methods
     93 
     94 You can use node's http client interface:
     95 
     96 ``` javascript
     97 var http = require('http');
     98 
     99 var request = http.request({
    100   method: 'post',
    101   host: 'example.org',
    102   path: '/upload',
    103   headers: form.getHeaders()
    104 });
    105 
    106 form.pipe(request);
    107 
    108 request.on('response', function(res) {
    109   console.log(res.statusCode);
    110 });
    111 ```
    112 
    113 Or if you would prefer the `'Content-Length'` header to be set for you:
    114 
    115 ``` javascript
    116 form.submit('example.org/upload', function(err, res) {
    117   console.log(res.statusCode);
    118 });
    119 ```
    120 
    121 To use custom headers and pre-known length in parts:
    122 
    123 ``` javascript
    124 var CRLF = '\r\n';
    125 var form = new FormData();
    126 
    127 var options = {
    128   header: CRLF + '--' + form.getBoundary() + CRLF + 'X-Custom-Header: 123' + CRLF + CRLF,
    129   knownLength: 1
    130 };
    131 
    132 form.append('my_buffer', buffer, options);
    133 
    134 form.submit('http://example.com/', function(err, res) {
    135   if (err) throw err;
    136   console.log('Done');
    137 });
    138 ```
    139 
    140 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:
    141 
    142 ``` javascript
    143 someModule.stream(function(err, stdout, stderr) {
    144   if (err) throw err;
    145 
    146   var form = new FormData();
    147 
    148   form.append('file', stdout, {
    149     filename: 'unicycle.jpg', // ... or:
    150     filepath: 'photos/toys/unicycle.jpg',
    151     contentType: 'image/jpeg',
    152     knownLength: 19806
    153   });
    154 
    155   form.submit('http://example.com/', function(err, res) {
    156     if (err) throw err;
    157     console.log('Done');
    158   });
    159 });
    160 ```
    161 
    162 The `filepath` property overrides `filename` and may contain a relative path. This is typically used when uploading [multiple files from a directory](https://wicg.github.io/entries-api/#dom-htmlinputelement-webkitdirectory).
    163 
    164 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:
    165 
    166 ``` javascript
    167 form.submit({
    168   host: 'example.com',
    169   path: '/probably.php?extra=params',
    170   auth: 'username:password'
    171 }, function(err, res) {
    172   console.log(res.statusCode);
    173 });
    174 ```
    175 
    176 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()`:
    177 
    178 ``` javascript
    179 form.submit({
    180   host: 'example.com',
    181   path: '/surelynot.php',
    182   headers: {'x-test-header': 'test-header-value'}
    183 }, function(err, res) {
    184   console.log(res.statusCode);
    185 });
    186 ```
    187 
    188 ### Integration with other libraries
    189 
    190 #### Request
    191 
    192 Form submission using  [request](https://github.com/request/request):
    193 
    194 ```javascript
    195 var formData = {
    196   my_field: 'my_value',
    197   my_file: fs.createReadStream(__dirname + '/unicycle.jpg'),
    198 };
    199 
    200 request.post({url:'http://service.com/upload', formData: formData}, function(err, httpResponse, body) {
    201   if (err) {
    202     return console.error('upload failed:', err);
    203   }
    204   console.log('Upload successful!  Server responded with:', body);
    205 });
    206 ```
    207 
    208 For more details see [request readme](https://github.com/request/request#multipartform-data-multipart-form-uploads).
    209 
    210 #### node-fetch
    211 
    212 You can also submit a form using [node-fetch](https://github.com/bitinn/node-fetch):
    213 
    214 ```javascript
    215 var form = new FormData();
    216 
    217 form.append('a', 1);
    218 
    219 fetch('http://example.com', { method: 'POST', body: form })
    220     .then(function(res) {
    221         return res.json();
    222     }).then(function(json) {
    223         console.log(json);
    224     });
    225 ```
    226 
    227 ## Notes
    228 
    229 - ```getLengthSync()``` method DOESN'T calculate length for streams, use ```knownLength``` options as workaround.
    230 - Starting version `2.x` FormData has dropped support for `node@0.10.x`.
    231 
    232 ## License
    233 
    234 Form-Data is released under the [MIT](License) license.