亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

如何使用python-dotenv解決代碼與敏感信息的分離

 更新時間:2022年03月30日 14:44:45   作者:foofish  
我們開發(fā)的每個系統(tǒng)都離不開配置信息,這些信息都非常敏感,一旦泄露出去后果非常嚴(yán)重,被泄露的原因一般是程序員將配置信息和代碼混在一起導(dǎo)致的,這篇文章主要給大家介紹了關(guān)于如何使用python-dotenv解決代碼與敏感信息的分離,需要的朋友可以參考下

“12-Factor” 是構(gòu)建SaaS服務(wù)的一種方法論,這套理論適用于任意語言和后端服務(wù)(數(shù)據(jù)庫、消息隊列、緩存等)開發(fā)的應(yīng)用程序。

其中有一條很重要的原則是關(guān)于配置的, 12-Factor 要求代碼和配置嚴(yán)格分離。

為什么要這么做?

如果你的代碼放在Github等外部網(wǎng)絡(luò),哪一天要是代碼不小心泄露了,你的各種密碼,密鑰,等配置全都暴露于公網(wǎng)中,這是一件非常可怕的事。

判斷一個應(yīng)用是否正確的將配置與代碼分離開了,一個簡單方法是你的代碼是否可以立刻開源,而不用擔(dān)心有任何敏感信息暴露。

將應(yīng)用的配置存儲于環(huán)境變量中是一種常規(guī)做法,例如在命令行中加入:

export PASSWORD=123456

windows

set PASSWORD=123456

業(yè)務(wù)代碼中,通過環(huán)境變量來加載。

import os
env = os.environ.get("PASSWORD")
print(env)

這樣做就不會將敏感信息暴露于業(yè)務(wù)代碼中了,同時也可以最大程度讓開發(fā)人員接觸正式環(huán)境的敏感信息。

不過,問題來了,將敏感信息設(shè)置成環(huán)境變量,如果這樣的信息非常多,挨個設(shè)置也太麻煩了。

你一定希望可以將這些敏感信息單獨放在一個文件中,始終與代碼分開管理

例如,我們在一個flask項目中,敏感信息我們專門放在一個叫.flaskenv 的文件中

.flaskenv 文件

FLASK_DEBUG=1
FLASK_ENV=local
AAA=1234

可是這些配置如何加載到環(huán)境變量中去?

python-dotenv

python-dotenv 就是專門干這事的,他能將配置文件的配置信息自動加入到環(huán)境變量。

安裝 python-dotenv

pip install python-dotenv

加載配置文件

from dotenv import load_dotenv
# 加載文件
load_dotenv(".flaskenv")
import os
flask_env = os.environ.get("FLASK_ENV")
print(flask_env) # local

加載文件后,就可以通過os.environ從環(huán)境變量中讀取內(nèi)容。

flask配置最佳實踐

在flask中,python-dotenv 可以無縫接入項目中,只要你的項目中存在 .env 或者 .flaskenv 文件,他就會提示你是否安裝 python-dotenv

$ flask run
 * Tip: There are .env files present. Do "pip install python-dotenv" to use them.

安裝完后python-dotenv后,就會自動加載里面的配置文件到環(huán)境變量中。

# config.py
class LocalConfig(BaseConfig):
    ENV = "development"
    FLASK_DEBUG = 1
    # 通過變量環(huán)境來加載數(shù)據(jù)庫配置
    SQLALCHEMY_DATABASE_URI = os.getenv("SQLALCHEMY_DATABASE_URI")

# app.py
def create_app():
    app = Flask(__name__)
    app.config.from_object(LocalConfig)

# view.py
def hello():
    # 加載環(huán)境變量
    os.environ.get("AAA")

你不需要自己去加載配置文件,因為flask-cli 幫你做了這個事,但是生產(chǎn)環(huán)境我們通常會基于gunicorn來部署我們的應(yīng)用,這時候就沒法自動加載了。你需要在生成app實例前顯式加載配置文件。

#run.py
from app import create_app
from dotenv import load_dotenv
load_dotenv('.flaskenv') 
app = create_app()

總結(jié)

到此這篇關(guān)于如何使用python-dotenv解決代碼與敏感信息的分離的文章就介紹到這了,更多相關(guān)python-dotenv代碼與敏感信息分離內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論