Храните секретный ключ AWS вне кода Javascript

У меня есть веб-приложение, использующее AWS Lambda и API Gateway (защищенное IAM) для серверной части, интерфейсная часть построена с использованием React. Я пытаюсь выяснить, как лучше всего не допускать использования секретного ключа AWS в производственном коде Javascript, пока я не могу найти ничего лучше, чем просто запутать ключ, но это ничего не решает.

Пока что в разработке я использую apigClient и жестко кодирую как ключ доступа, так и секретный ключ.

Любая помощь могла бы быть полезна.

Спасибо.

Может быть, создать файл json с вашими учетными данными aws? Затем в своем коде вы импортируете файл и получаете то, что хотите.

Addict 21.11.2018 16:23

Я надеюсь, вы имеете в виду, что в коде бэкэнд этого точно не должно быть в приложении React. Поскольку вы находитесь на AMS, вы можете заглянуть в KMS, чтобы помочь управлять этими секретами.

jonrsharpe 21.11.2018 16:28

У нас была такая же головная боль. В итоге мы использовали Cognito. Если ваше приложение аутентифицируется с помощью Cognito, AWS может предоставить ему федеративный доступ ко всему, что вам нужно. Конечно, тогда у вас есть проблема с получением имени пользователя Cognito и pwd для вашего приложения. Но если это услуга, на которую подписаны пользователи, то об этом, я думаю, можно позаботиться при регистрации, отправив письмо по электронной почте. Когда потребность этого пользователя в доступе исчезнет, ​​удалите его пользователя Cognito. Никаких ключей AWS нигде не требуется. Не знаю, помогает ли это или я ошибаюсь? Привет, Адам.

Adam Benson 23.11.2018 13:50
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
0
3
777
2

Ответы 2

Все, что вы включаете в свой код javascript, будет доступно для чтения в браузере, если кто-то проверит исходный код вашего окончательного пакета.

Если вы хотите быть на 100% уверенным, что ваш секретный ключ остается скрытым, вам следует выполнить эту аутентификацию в бэкэнде.

Однако вы можете хранить секретные ключи вне репо, настроив их как переменные env.

AWS имеет интерфейс для переменных среды в своих приложениях. Похоже, это документы для Lambda. Вы должны ввести любые учетные данные в этот интерфейс, и тогда вы сможете получить к ним доступ в своей функции Lambda. Локально вы можете использовать npm, например точка-env, и использовать файл .env для доступа к вашим переменным окружения. Или вы можете просто добавить их в свою командную строку. Если вы собираетесь использовать файл .env, ОЧЕНЬ ВАЖНО, чтобы вы проигнорировали этот файл в вашем .gitignore.

Другие вопросы по теме