我没有从Amazon Lambda获得适当的JSON响应

时间:2017-02-27 14:41:00

标签: json node.js amazon-web-services aws-lambda alexa

嘿,StackOverflow有帮助的人!我发现自己需要一些帮助和专业知识。我正在关注创建Amazon Alexa技能的教程,当我测试lambda函数的代码时,它成功了,但是,当我使用我指定给它的示例话语时,它是"得到当前的天气" (不要介意话语与实际端点无关,此时我正在使用json占位符的端点:https://jsonplaceholder.typicode.com/users因为我只想要一个响应,任何类型的响应)。我一定会感谢任何形式的帮助!先谢谢你们的家伙和女孩们!

这是我的代码:

var https = require("https");



exports.handler = (event, context) => {

  try{

    if (event.session.new){
    // New Session
    console.log("new session!");
}
  switch (event.request.type){

    case "LaunchRequest":
    // > Launch Request
      console.log("launch request!");
      context.succeed(
        generateResponse(
          buildSpeechletResponse("Welcome!!!!!!!! Let's make this work!", true),
          {}
          )
      )
      break;

    case "IntentRequest":
    // > Intent Request
      console.log("intent request!"); // endpoint added here below
      switch(event.request.intent.name){
        case "getWeatherIntent":
          var endpoint = "https://jsonplaceholder.typicode.com/users"; // this works with this "placebo endpoint data" https://jsonplaceholder.typicode.com/posts ***** api.openweathermap.org/data/2.5/weather?zip=10005,us&APPID=08d6215ef934232110949692d5ffb8da
          var body = ""
          https.get(endpoint, (response) => {
            response.on('data', (chunk) => {body += chunk})
            response.on('end', () => {
              var data = JSON.parse(body);
              var weatherCount = data.userId; // might have something to do with this variable
              context.succeed(
                generateResponse(
                  buildSpeechletResponse("current is ${weatherCount}", true),
                  {}
                  )
                )
            })
          })
      }
      break; // endpoint added here above

    case "SessionEndedRequest":
    // > Session Ended Request
      console.log("session ended request!");
      break;

    default:
      context.fail("invalid request type!: {event.request.type}");
  }

  } catch(error) {context.fail("Exception: ${error}")}



}

// Helpers
buildSpeechletResponse = (outputText, shouldEndSession) => {
  return{
    outputSpeech:{
      type: "PlainText",
      text: outputText
    },
    shouldEndSession: shouldEndSession
  }
}

generateResponse = (speechletResponse, sessionAttributes) => { 
  return {
    version: "1.0",
    sessionAttributes: sessionAttributes,
    response: speechletResponse
  }
}

此处还有意图架构:

{
  "intents":[
   { "intent": "getWeatherIntent"
   }
  ]
}

这是lambda请求:

{
  "session": {
    "sessionId": "SessionId.51e05faf-df95-420f-9cfc-3736b1839482",
    "application": {
      "applicationId": "amzn1.ask.skill.482872e5-20a2-4230-bce4-a06b212443e5"
    },
    "attributes": {},
    "user": {
      "userId": "amzn1.ask.account.AFOFPAF44SZKQRQDFH3FW7PZCVEZPXLLPPWT7CO76Z62I2DVI5EFTYSFD3YMEA56R4ACYUSPTPVFGCA2BCFJCNBVLBNWAWSIOCXHCDTW5UM5WNIRE6K35XZ67CM3W2DN3NLIPRVEFWBZ3D6ASD37EYJWBQQFOK4FXB5NMGQCLJVGBJKUJMCZXVEHXU74KLSDXOV5MIF3UZPFLRA"
    },
    "new": true
  },
  "request": {
    "type": "IntentRequest",
    "requestId": "EdwRequestId.4b18c102-47ea-4855-a5da-6407379c0384",
    "locale": "en-US",
    "timestamp": "2017-02-28T02:13:25Z",
    "intent": {
      "name": "getWeatherIntent",
      "slots": {}
    }
  },
  "version": "1.0"
}

这是lambda响应:

{
  "version": "1.0",
  "response": {
    "outputSpeech": {
      "type": "PlainText",
      "text": "current is ${weatherCount}"
    },
    "shouldEndSession": true
  },
  "sessionAttributes": {}
}

变量$ {weatherCount}是否已经返回从JSON解析的内容而不是按原样返回?

以下是将模板文字的引号更改为反引号(更改" $ {weatherCount}"到${weatherCount})之后的新Lambda响应,因此我们可能会遇到某些事情!:

{
  "version": "1.0",
  "response": {
    "outputSpeech": {
      "type": "PlainText",
      "text": "current is [object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object]"
    },
    "shouldEndSession": true
  },
  "sessionAttributes": {}
}

它现在正在工作!关键是将模板文字周围的引号更改为反引号。以下是新的lambda请求和新的lambda响应。

Lamdba请求:

{
  "session": {
    "sessionId": "SessionId.9f8cc454-110f-4610-a7fe-cd0918fd804f",
    "application": {
      "applicationId": "amzn1.ask.skill.482872e5-20a2-4230-bce4-a06b212443e5"
    },
    "attributes": {},
    "user": {
      "userId": "amzn1.ask.account.AFOFPAF44SZKQRQDFH3FW7PZCVEZPXLLPPWT7CO76Z62I2DVI5EFTYSFD3YMEA56R4ACYUSPTPVFGCA2BCFJCNBVLBNWAWSIOCXHCDTW5UM5WNIRE6K35XZ67CM3W2DN3NLIPRVEFWBZ3D6ASD37EYJWBQQFOK4FXB5NMGQCLJVGBJKUJMCZXVEHXU74KLSDXOV5MIF3UZPFLRA"
    },
    "new": true
  },
  "request": {
    "type": "IntentRequest",
    "requestId": "EdwRequestId.229831d9-3bd1-4173-a1c4-7664994a1a77",
    "locale": "en-US",
    "timestamp": "2017-02-28T02:39:30Z",
    "intent": {
      "name": "getWeatherIntent",
      "slots": {}
    }
  },
  "version": "1.0"
}

新的Lambda回应:

{
  "version": "1.0",
  "response": {
    "outputSpeech": {
      "type": "PlainText",
      "text": "current is 1"
    },
    "shouldEndSession": true
  },
  "sessionAttributes": {}
}

1 个答案:

答案 0 :(得分:2)

在我看来,这似乎是您template literals的一个问题。模板文字需要用反引号包装而不是单引号或双引号。使用反引号替换所有使用模板文字的字符串的引号。

例如:

"current is ${weatherCount}"

变为:

`current is ${weatherCount}`

其他问题排查提示:

  • 确保您使用AWS Lambda可用的最新版本的节点;在撰写本文时,即v4.3.2。较旧版本的节点不支持模板文字。

  • 如果没有执行这两个步骤,只需将模板文字替换为变量即可将其排除在外。

  • console.log输出写入AWS Lambda中的cloudwatch - 您可以使用它来调试lambda函数的每个调用。更多信息:http://docs.aws.amazon.com/lambda/latest/dg/nodejs-prog-model-logging.html