I think that the cleaner and more performant way, without the need for externals libs can be something like this:
const https = require('https');
const doPostRequest = () => {
const data = {
value1: 1,
value2: 2,
};
return new Promise((resolve, reject) => {
const options = {
host: 'www.example.com',
path: '/post/example/action',
method: 'POST',
headers: {
'Content-Type': 'application/json'
}
};
//create the request object with the callback with the result
const req = https.request(options, (res) => {
resolve(JSON.stringify(res.statusCode));
});
// handle the possible errors
req.on('error', (e) => {
reject(e.message);
});
//do the request
req.write(JSON.stringify(data));
//finish the request
req.end();
});
};
exports.handler = async (event) => {
await doPostRequest()
.then(result => console.log(`Status code: ${result}`))
.catch(err => console.error(`Error doing the request for the event: ${JSON.stringify(event)} => ${err}`));
};
This lambda has been made and tested on the following Runtimes: Node.js 8.10
and Node.js 10.x
and is able to do HTTPS requests, to do HTTP requests you need to import and change the object to http
:
const http = require('http');
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…