【发布时间】:2019-03-24 23:48:04
【问题描述】:
我使用 lambda 函数为 s3 存储桶添加了网站身份验证,然后使用分发设置中的行为设置将 lambda 函数与 CloudFront 连接,它工作正常并添加了身份验证(意味着简单服务器中的 htaccess 身份验证)。现在我想更改我的网站身份验证的密码。为此,我更新了密码并发布了新版本的 lambda 函数,然后在分发设置中;我创建了一个新的失效来清除缓存。但它不起作用,并且网站验证密码没有改变。下面是我添加身份验证的 lambda 函数代码。
'use strict';
exports.handler = (event, context, callback) => {
// Get request and request headers
const request = event.Records[0].cf.request;
const headers = request.headers;
// Configure authentication
const authUser = 'user';
const authPass = 'pass';
// Construct the Basic Auth string
const authString = 'Basic ' + new Buffer(authUser + ':' + authPass).toString('base64');
// Require Basic authentication
if (typeof headers.authorization == 'undefined' || headers.authorization[0].value != authString) {
const body = 'Unauthorized';
const response = {
status: '401',
statusDescription: 'Unauthorized',
body: body,
headers: {
'www-authenticate': [{key: 'WWW-Authenticate', value:'Basic'}]
},
};
callback(null, response);
}
// Continue request processing if authentication passed
callback(null, request);
};
谁能帮我解决这个问题。
提前致谢。
【问题讨论】:
-
我猜你的 lambda 应该被部署到 Lambda@Edge (us-east-1)。不确定 backet...
-
你能解释一下吗,如何?
标签: amazon-web-services amazon-s3 aws-lambda amazon-cloudfront