- Notifications
You must be signed in to change notification settings - Fork380
A module to create readable `"multipart/form-data"` streams. Can be used to submit forms and file uploads to other web applications.
License
form-data/form-data
Folders and files
| Name | Name | Last commit message | Last commit date | |
|---|---|---|---|---|
Repository files navigation
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 theXMLHttpRequest-2 FormData Interface.
npm install --save form-dataIn this example we are constructing a form with 3 fields that contain a string,a buffer and a file stream.
varFormData=require('form-data');varfs=require('fs');varform=newFormData();form.append('my_field','my value');form.append('my_buffer',newBuffer(10));form.append('my_file',fs.createReadStream('/foo/bar.jpg'));
Also you can use http-response stream:
varFormData=require('form-data');varhttp=require('http');varform=newFormData();http.request('http://nodejs.org/images/logo.png',function(response){form.append('my_field','my value');form.append('my_buffer',newBuffer(10));form.append('my_logo',response);});
Or @mikeal'srequest stream:
varFormData=require('form-data');varrequest=require('request');varform=newFormData();form.append('my_field','my value');form.append('my_buffer',newBuffer(10));form.append('my_logo',request('http://nodejs.org/images/logo.png'));
In order to submit this form to a web application, callsubmit(url, [callback]) method:
form.submit('http://example.org/',function(err,res){// res – response object (http.IncomingMessage) //res.resume();});
For more advanced request manipulationssubmit() method returnshttp.ClientRequest object, or you can choose from one of the alternative submission methods.
You can provide custom options, such asmaxDataSize:
varFormData=require('form-data');varform=newFormData({maxDataSize:20971520});form.append('my_field','my value');form.append('my_buffer',/* something big */);
List of available options could be found incombined-stream
You can use node's http client interface:
varhttp=require('http');varrequest=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:
varCRLF='\r\n';varform=newFormData();varoptions={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)throwerr;console.log('Done');});
Form-Data can recognize and fetch all the required information from common types of streams (fs.readStream,http.response andmikeal'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)throwerr;varform=newFormData();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)throwerr;console.log('Done');});});
Thefilepath property overridesfilename and may contain a relative path. This is typically used when uploadingmultiple 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 toform.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 theheaders key in first parameter ofform.submit():
form.submit({host:'example.com',path:'/surelynot.php',headers:{'x-test-header':'test-header-value'}},function(err,res){console.log(res.statusCode);});
- Void append(Stringfield,Mixedvalue [,Mixedoptions] ).
- Headers getHeaders( [HeadersuserHeaders] )
- String getBoundary()
- Void setBoundary()
- Buffer getBuffer()
- Integer getLengthSync()
- Integer getLength(functioncallback )
- Boolean hasKnownLength()
- Request submit(params,functioncallback )
- String toString()
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.
varform=newFormData();form.append('my_string','my value');form.append('my_integer',1);form.append('my_boolean',true);form.append('my_buffer',newBuffer(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 optionsform.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});
This method adds the correctcontent-type header to the provided array ofuserHeaders.
Return the boundary of the formData. By default, the boundary consists of 26- followed by 24 numbersfor example:
--------------------------515890814546601021194782
Set the boundary string, overriding the default behavior described above.
Note: The boundary must be unique and may not appear in the data.
Return the full formdata request package, as a Buffer. You can insert this Buffer in e.g. Axios to send multipart data.
varform=newFormData();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.
Same asgetLength but synchronous.
Note: getLengthSyncdoesn't calculate streams length.
Returns theContent-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 lengthrequest.setHeader('Content-Length',length); ...}.bind(this));
Checks if the length of added values is known.
Submit the form to a web application.
varform=newFormData();form.append('my_string','Hello World');form.submit('http://example.com/',function(err,res){// res – response object (http.IncomingMessage) //res.resume();});
Returns the form data as a string. Don't use this if you are sending files or buffers, usegetBuffer() instead.
Form submission usingrequest:
varformData={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){returnconsole.error('upload failed:',err);}console.log('Upload successful! Server responded with:',body);});
For more details seerequest readme.
You can also submit a form usingnode-fetch:
varform=newFormData();form.append('a',1);fetch('http://example.com',{method:'POST',body:form}).then(function(res){returnres.json();}).then(function(json){console.log(json);});
In Node.js you can post a file usingaxios:
constform=newFormData();conststream=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`constformHeaders=form.getHeaders();axios.post('http://example.com',form,{headers:{ ...formHeaders,},}).then(response=>response).catch(error=>error)
getLengthSync()method DOESN'T calculate length for streams, useknownLengthoptions 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 usingknownLength).submitwill not addcontent-lengthif form length is unknown or not calculable.- Starting version
2.xFormData has dropped support fornode@0.10.x. - Starting version
3.xFormData has dropped support fornode@4.x.
Form-Data is released under theMIT license.
About
A module to create readable `"multipart/form-data"` streams. Can be used to submit forms and file uploads to other web applications.
Topics
Resources
License
Uh oh!
There was an error while loading.Please reload this page.