这些结果是针对通过API网关和lambda进行的GET和POST请求响应的。使用了相同的lambda函数,但是当我使用API网关的post方法时,响应只是向我显示JSON。我该怎么办?
when i used get req 这是我的lambda函数
exports.handler = (event, context, callback) => {
const response = {
statusCode: 301,
headers: {
Location: 'https://google.com',
}
};
return callback(null, response);
}
谢谢。
答案 0 :(得分:0)
GET请求将返回响应中提供的任何内容。在这种情况下,它是JSON对象 response 。对于POST请求,相同的 response 对象将返回给API网关,API网关随后将其按原样返回给客户端。
答案 1 :(得分:0)
在定义aws lambda时,我通常使用新的async/await
模式:
exports.handler = async (event) => {
// do stuff...
}
通常,您不需要context
,除非您想使用一些有关lambda的与AWS相关的信息。
我有一个辅助函数,在代码库中得到了很多重复使用
function proxyResponse(inBody, inStatusCode = null, headers = {}, event = null) {
if (!isApiGateway(event)) {
if (inBody instanceof Error) {
throw inBody;
}
return inBody;
}
let statusCode = inStatusCode;
let body;
if (inBody instanceof Error) {
statusCode = statusCode || INTERNAL_SERVER_ERROR;
body = JSON.stringify({
message: inBody.message,
code: statusCode,
});
} else if (inBody instanceof Object) {
body = JSON.stringify(inBody);
} else {
body = inBody;
}
const [origin] = event ? caseHandler(event.headers, 'origin') : [];
return {
statusCode: statusCode || 200,
body,
headers: Object.assign({
'Access-Control-Allow-Headers': 'Content-Type,Authorization,X-Amz-Date,X-Api-Key,X-Amz-Security-Token,x-api-key,Authorization',
'Access-Control-Allow-Origin': origin,
'Access-Control-Allow-Credentials': true,
'Access-Control-Allow-Methods': 'DELETE,GET,HEAD,OPTIONS,PATCH,POST,PUT',
}, headers),
};
}
和另一个:
function caseHandler(mixedCaseObject, inputKey) {
if (!mixedCaseObject || !inputKey) {
return [];
}
return Object.keys(mixedCaseObject)
.filter((key => key.toLowerCase() === inputKey.toLowerCase()))
.map(key => mixedCaseObject[key]);
}
和这个:
function isApiGateway(event) {
return (!!event.httpMethod && !!event.headers && !!event.requestContext);
}
因此,在lambda内,每当我想返回一些东西时,我都会使用以下辅助函数:
module.exports.handler = async (event) => {
try{
// do stuff...
return proxyResponse(YOUR_CUSTOM_BODY_OBJECT, Api.HTTP.OK, {}, event);
} catch(error) {
return proxyResponse(error, Api.HTTP.INTERNAL_SERVER_ERROR, {}, event);
}
}