python庫-dotenv包 及 .env配置文件詳解

python庫-dotenv包 | .env配置文件

背景

我們開發的每個系統都離不開配置信息,這些信息都非常敏感,一旦泄露出去後果非常嚴重,被泄露的原因一般是程序員將配置信息和代碼混在一起導致的。

一般業務代碼中,通過環境變量來加載敏感信息。

將敏感信息設置成環境變量,但是這樣的信息非常多,挨個設置也太麻煩瞭。你一定希望可以將這些敏感信息單獨放在一個文件中,始終與代碼分開管理。

在python項目中,敏感信息(如數據庫密碼)比較推薦使用 .env文件來單獨管理,且不納入git管理中。而目前比較流行的解析.env則是python-dotenv。

python-dotenv 能將配置文件的配置信息自動加入到環境變量。 python-dotenv解決瞭代碼與敏感信息的分離

flask官方推薦使用python-dotenv包來管理特殊的配置。

python-dotenv 如何使用

使用思路:最簡單和最常見的用法是在應用程序啟動時調用load_dotenv,從當前目錄或其父目錄中的.env文件或指定的路徑加載環境變量,然後你可以調用os.getenv提供的與環境相關的方法。

load_dotenv默認不會更新已經存在的配置項。推薦使用override參數,如下:

from dotenv import load_dotenv, find_dotenv
load_dotenv(find_dotenv(), override=True)
  • dotenv_path: 指定.env文件路徑,當然如果不傳該參數的話(默認為None)也會自定調用dotenv.find_dotenv()去查找文件位置的,但是你的文件名如果不是.env那就必須傳遞該參數
  • override: 當.env 文件中有變量與系統中原來的環境變量有沖突時,按照上面的取值順序,默認使用系統變量,如果要用.env中的變量覆蓋系統變量,可以給load_dotenv() 傳遞參數override=True。此時隻是臨時使用瞭.env 中的變量值
import os
from dotenv import find_dotenv, load_dotenv
# 加載.env文件到環境變量
load_dotenv(find_dotenv('.env'))
print(os.environ.get("URL"))

加載文件後,就可以通過os.environ從環境變量中讀取內容。

到此這篇關於python庫-dotenv包 | .env配置文件的文章就介紹到這瞭,更多相關python env配置文件內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: