[使用`requestjs`从节点Js调用AWS Lambda端点时始终会出现502错误

问题描述 投票:0回答:2

[尝试使用Node.js Request包在我们的AWS无服务器api中发布数据,但始终会出现502错误,并且可以从前端应用程序(React或Jquery)发布数据。


var dataToPost = {
name: 'ABC',
address: 'XYZ'
}

request(
    { method: 'POST'
    , uri: 'url here...'
    , headers: {
    'User-Agent': 'request'
  } , multipart:
      [ { 'content-type': 'application/json'
        ,  body: JSON.stringify(dataToPost)
        }
      ]
    }
  , function (error, response, body) {
      if(response.statusCode == 201){
        console.log('document saved')
      } else {
        console.log('error: '+ response.statusCode)
        console.log(body)
      }
    }
  )```
node.js aws-lambda http-post requestjs
2个回答
0
投票

通常,如果lambda未正确返回响应,则返回“ 502格式错误的响应”。

您是从lambda返回一个字符串化的主体吗? Lambda应该返回如下响应。

{
    "isBase64Encoded": true|false,
    "statusCode": httpStatusCode,
    "headers": { "headerName": "headerValue", ... },
    "body": "..."
}

许多人忘记将身体拉细。


0
投票

如果您能够使用react和Jquery发布数据,则可能是您未正确发出发布请求。请尝试以下代码进行发布请求:

const request = require('request');
var dataToPost = {
    name: 'ABC',
    address: 'XYZ'
        }
const options = {
    url: 'url goes here',
    json: true,
    body: dataToPost
};

request.post(options, (err, res, body) => {
    if (err) {
        return console.log(err);
    }
    console.log(`Status: ${res.statusCode}`);
    console.log(body);
});

或者,您也可以使用axios,它使代码更具可读性并具有内置的Promise支持:

const axios = require('axios');
var dataToPost = {
    name: 'ABC',
    address: 'XYZ'
        }
const url = 'put url here'
axios.post(url, data)
    .then((res) => {
        console.log(`Status: ${res.status}`);
        console.log('Body: ', res.data);
    }).catch((err) => {
        console.error(err);
    });

还请检查AWS Lmbada日志说了什么。

© www.soinside.com 2019 - 2024. All rights reserved.