【问题标题】:returning response with set-cookie header in AWS Cloudfront origin request在 AWS Cloudfront 源请求中返回带有 set-cookie 标头的响应
【发布时间】:2021-12-29 05:24:54
【问题描述】:

在我的 CloudFront 原始请求 lambda@edge 函数中,我想返回一个响应,该响应将在浏览器中设置一个 cookie 值并重定向到其他页面。我通过以下返回语句来做到这一点:

return {
  status: '302',
  statusDescription: 'Found',
  headers: {
    location: [
      { key: 'Location', value: 'my.website.com' },
    ],
    'set-cookie': [
      { key: 'Set-Cookie', value: 'key=value; Max-Age=600' },
    ]
  }
};

不幸的是,CloudFront 似乎删除/忽略了这个 set-cookie 标头,并且浏览器收到了没有它的响应。有趣的是,完全相同的代码在放置在 CloudFront 查看器请求函数中时会起作用。有没有办法让 origin-request lambda 在响应中保留 set-cookie 标头?

【问题讨论】:

    标签: amazon-web-services amazon-cloudfront


    【解决方案1】:

    解决方案是使用正确的白名单 cookie 名称启用 Cookies - include specified cookies 选项的缓存策略。问题中的行为是由以下原因引起的(如documentation 所述):

    不要将 cookie 转发到您的源 – CloudFront 不会根据查看器发送的 cookie 缓存您的对象。 此外,CloudFront 会在将请求转发到您的源之前删除 cookie,并在将响应返回给您的查看器之前从响应中删除 Set-Cookie 标头。

    要防止通过列入白名单的 cookie 名称进行缓存,请将以下标头添加到响应中:Cache-Control: no-cache="Set-Cookie"

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2015-09-20
      • 1970-01-01
      • 2018-03-16
      • 2017-04-06
      • 2013-05-30
      • 2021-07-02
      • 2012-05-02
      相关资源
      最近更新 更多