如何解决在heroku上设置环境变量 如何加载.env文件在 Heroku 中设置环境变量
我尝试通过我的 github 存储库在 heroku 上部署我的一个项目。我有一个 .env 文件,里面有我的 API 密钥和私有令牌。我想公开我的回购,但这意味着向所有人透露我的 .env 文件。我尝试搜索如何为 heroku 设置 .env ,但找到的答案让我更加困惑。那么有没有办法在我从 github 存储库中删除我的 env 变量时将它们提供给 herkou?
解决方法
您的 .env
密钥是保密的,应该保持保密。不用担心,您可以公开您的存储库,同时仍将您的密钥保密。
从背面看,.env
文件是一个隐藏文件。在将其推送到版本控制之前,您应该忽略此文件。在您的顶级目录中添加一个 .gitignore
文件,并提供您希望从版本控制中忽略的所有文件。您可以检查 here 以查看您可能想要忽略哪些文件。
如果您已经将您的密钥提交到 github,这意味着这些密钥的在线副本是可用的,我建议您为 .env
文件中的每个变量生成新密钥。这将是最简单的方法。如果 .env
文件已在 .gitignore
中列出,那么您的下一次提交将从版本控制中省略该文件及其内容。
如何加载.env
文件
假设您具有如下所示的简单结构,其中您的 .env
和 config.py
文件位于顶级目录中:
project
| --- .env
| --- config.py
| --- requirements.txt
| --- app/
首先,您需要在虚拟环境中安装 python-dotenv
。这个包有助于加载环境变量。
(venv)$ pip3 install python-dotenv && pip3 freeze > requirements.txt
在您的配置模块中,加载 .env
:
# config.py
import os
from dotenv import load_dotenv
load_dotenv('.env')
class Config(object):
SECRET_KEY = os.environ.get('SECRET_KEY')
您的 .env
文件应该有这个密钥:
# .env
SECRET_KEY=<you-will-never-guess>
在 Heroku 中设置环境变量
在您的终端中,您可以设置 .env
的值:
(venv)$ heroku config:set SECRET_KEY=<you-will-never-guess>
为了帮助您的应用程序感兴趣的用户了解他们在本地测试应用程序时需要哪些密钥,请创建一个名为 .env-template
的文本文件并创建您的环境变量而不传递它们的实际值:
# .env-template
SECRET_KEY=
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。