Oui, je sais qu'il s'agit d'un doublon, mais les choses ont changé depuis que la solution de modèle de mappage fournie ici , ici et ici a été conçue. Avec une intégration proxy (l'approche recommandée par AWS), il n'y a pas d'accès aux modèles. Alors, comment obtenez-vous les en-têtes maintenant?
J'ai essayé d'utiliser le modèle objet avec des choses comme:
event.headers
event.headers["X-Requested-With"]
var headerItem = "x-requested-with"
event.headers.headerItem
etc. et rien ne semble être défini.
L'événement, selon Cloudwatch, est:
{
"resource": "/contactformlambda",
"path": "/contactformlambda",
"httpMethod": "POST",
"headers": {
"Accept": "application/json, text/plain, */*",
"Accept-Encoding": "gzip, deflate, br",
"Accept-Language": "en-US,en;q=0.9",
"cache-control": "no-cache",
"CloudFront-Forwarded-Proto": "https",
"CloudFront-Is-Desktop-Viewer": "true",
"CloudFront-Is-Mobile-Viewer": "false",
"CloudFront-Is-SmartTV-Viewer": "false",
"CloudFront-Is-Tablet-Viewer": "false",
"CloudFront-Viewer-Country": "AU",
"content-type": "text/plain",
"Host": "ovo5xmxf7e.execute-api.ap-southeast-2.amazonaws.com",
"Origin": "http://localhost:4200",
"pragma": "no-cache",
"Referer": "http://localhost:4200/contact",
"User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.140 Safari/537.36",
"Via": "2.0 49d473f12cd3746d92748f257e16ca9e.cloudfront.net (CloudFront)",
"X-Amz-Cf-Id": "7_PvRhkwbB7wmB1n8EFgE9s84q1xPYZ_uKwAjwYPXSv383M-fmDTgQ==",
"X-Amzn-Trace-Id": "Root=1-5a826e92-b4425f8069686c808cc2d500",
"X-Forwarded-For": "155.144.114.41, 54.240.152.46",
"X-Forwarded-Port": "443",
"X-Forwarded-Proto": "https",
"x-requested-with": "Angular5"
},
"queryStringParameters": null,
"pathParameters": null,
"stageVariables": null,
"requestContext": {
"requestTime": "13/Feb/2018:04:50:26 +0000",
"path": "/prod/contactformlambda",
"accountId": "499908792600",
"protocol": "HTTP/1.1",
"resourceId": "i6i1qv",
"stage": "prod",
"requestTimeEpoch": 1518497426058,
"requestId": "683aeec6-1079-11e8-a419-318ae32195ef",
"identity": {
"cognitoIdentityPoolId": null,
"accountId": null,
"cognitoIdentityId": null,
"caller": null,
"sourceIp": "155.144.114.41",
"accessKey": null,
"cognitoAuthenticationType": null,
"cognitoAuthenticationProvider": null,
"userArn": null,
"userAgent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.140 Safari/537.36",
"user": null
},
"resourcePath": "/contactformlambda",
"httpMethod": "POST",
"apiId": "ovo5xmxf7e"
},
"body": "{\"subject\":\"Enquiry from ZenithWebFoundry\",\"name\":\"Mike\",\"number\":\"0415118180\",\"email\":\"[email protected]\",\"comment\":\"this is a test from localhost\"}",
"isBase64Encoded": false
}
L'en-tête "x-required-with" est là, mais il ne semble jamais être défini, lorsque j'essaie d'y accéder par programme
Il doit être dans event.headers
.
De documentation , il indique ...
{
"resource": "Resource path",
"path": "Path parameter",
"httpMethod": "Incoming request's method name"
"headers": {Incoming request headers}
"queryStringParameters": {query string parameters }
"pathParameters": {path parameters}
"stageVariables": {Applicable stage variables}
"requestContext": {Request context, including authorizer-returned key-value pairs}
"body": "A JSON string of the request payload."
"isBase64Encoded": "A boolean flag to indicate if the applicable request payload is Base64-encode"
}
Mise à jour (basée sur vos nouvelles informations fournies):
L'en-tête que vous recherchez est x-requested-with
NE PAS X-Requested-With
(notez le boîtier).
// This will yield nothing, as it is the wrong key
event.headers['X-Requested-With']
// This will give you what you need.
event.headers['x-requested-with']
Notez que la recherche d'objets en Javascript est sensible à la casse.
Si vous souhaitez le récupérer à l'aide d'une variable, vous pouvez procéder comme suit ...
var headerItem = "x-requested-with"
event.headers[headerItem]