我在 Heroku 和 AWS EC2 中部署了一个应用程序。我还为我的存储创建了一个 AWS S3,用于上传图像和视频。突然 Heroku 给我发了一封电子邮件,说我的应用程序受到了最近的漏洞的影响,并且我的 AWS S3 访问密钥被盗(可能是因为我的访问密钥的机器人,而且我的存储库也是私有的,所以我不知道这是怎么发生的),我很高兴我早早看到了它,我能够删除我的密钥并生成一个新密钥。基本上我上传图片的代码是这样的。
从我的代码中的 .json 文件访问密钥。
{
"accessKeyId": "xxxxxxxxxxxxx",
"secretAccessKey": "xxxxxxxxxxxxxxxxxxxx",
"region": "us-east-2"
}
我的中间件
const multer = require('multer');
const AWS = require('aws-sdk');
const multerS3 = require('multer-s3');
AWS.config.loadFromPath('./resources/AwsS3Key.json');
var s3 = new AWS.S3();
const s3Storage = multerS3({
s3 : s3,
bucket : 'entrenami-app-bucket',
acl : 'public-read',
key : function (req, file, callback) {
callback(null, file.originalname);
}
});
module.exports.s3Upload = multer({ storage: s3Storage });
然后我将我的中间件连接到我的快速路由器以上传图像或视频。
它写在 AWS 文档中,我不应该把我的访问密钥和我的源代码放在一起。所以我将它添加到 gitignore。现在,当我在 AWS EC2 或 Heroku 中部署我的应用程序时,我将如何访问我的访问密钥?我不知道如何使用 ENV 变量访问我的密钥,请帮助我,我一直在阅读文档,但我无法完全理解它。先感谢您。