我们开发的每个系统都离不开配置信息,例如数据库密码、Redis密码、邮件配置、各种第三方配置信息,这些信息都非常敏感,一旦泄露出去后果非常严重,被泄露的原因一般是程序员将配置信息和代码混在一起导致的。 判断一个系统是否正确地将配置排除在代码之外,一个简单的方法是看该系统的代码是否可以立刻开源,而不用担心会暴露任何敏感信息。 所以我们做的第一件事情就是将配置信息与代码解耦,根据不同的部署环境(开发环境、测试环境、预发布、生产环境)各使用一套配置文件,然后将配置信息集中到配置文件中。 例如在 django 最佳实践里面,就有这种做法,每个部署环境都有一个独立的配置文件,因为每个部署环境所需要的配置各不相同。 ```python ├── settings │   ├── __init__.py │   ├── base.py │   ├── local.py │   ├── production.py │   └── test.py ``` 系统启动的时候,根据指定的环境变量决定加载哪个配置文件。 ```python if __name__ == "__main__": os.environ.setdefault("DJANGO_SETTINGS_MODULE", "settings.local") ``` 这样就完了吗? 不,因为配置信息还是和项目代码捆绑在一起,如果配置文件与代码同步到版本控制系统又担心敏感信息泄露。 前面只是将配置与代码解耦,但是代码与敏感配置信息并没有完全隔离。 一个更好的办法就是将配置存储于环境变量中,环境变量可以非常方便地在不同的部署间做修改,却不动一行代码,而这些信息同步到代码库的概率微乎其微。 在代码中我们通过读取环境变量中的配置信息来获取该值。 ```python settings.py MAIL_SERVER = os.getenv('MAIL_SERVER') MAIL_USERNAME = os.getenv('MAIL_USERNAME') MAIL_PASSWORD = os.getenv('MAIL_PASSWORD') ``` 现在哪怕代码开源出去,也没人知道密码是什么。 将配置信息保存在变量环境中,有好几种方式,一种就是手动在命令行挨个设置到环境变量中,类似于: ```python EXPORT SECRET_KEY=xxxxx EXPORT SQLALCHEMY_DATABASE_URI=XXXX EXPORT ACCESSKEYID=XXXXX ``` 这种方式很麻烦,每次启动都需要设,虽然你也可以写到类似 .bashrc 这样的文件中。 第二种方式是把配置信息写在supervisor中,如果你的系统是用supervisor来管理进程的话,supervisor 中可以设置环境变量,如: ```python [program:xxxx] environment= KEY=value, Key2=value2, key3="val.&" ``` 但是这种方式与 supervisor 的本身配置耦合在一起,用起来比较混乱。 而今天推荐的这个工具 `python-dotenv` 就可以完全独立于其它配置,只针对应用本身使用的配置信息,你只需要把配置信息全部写入到项目根目录的 `.env` 文件中 例如这样: ``` REDIS_ADDRESS=localhost:6379 MEANING_OF_LIFE=42 MULTILINE_VAR="hello\nworld" ``` 这个文件我们不放在git版本控制系统中。然后用一行代码来加载配置信息到环境变量中 ```python # settings.py from dotenv import load_dotenv load_dotenv() ``` 加载完成后就可以通过 `os.getenv` 方法去获取所有的配置信息。 ```python # settings.py import os SECRET_KEY = os.getenv("EMAIL") DATABASE_PASSWORD = os.getenv("DATABASE_PASSWORD") ``` 这样就完全将敏感信息脱离于代码,同时代码与配置也进行了解耦。 python-dov 的安装用普通的pip安装即可 ```python pip install -U python-dotenv ``` 这种使用方式在 django、flask 应用开发中很常见,而且他们基于此库也做了自己的扩展,例如 flask 中可以用 `.flaskenv` 来代替 `.env` 文件。 无

转载于:https://www.cnblogs.com/zhijun/p/11393200.html

试试 python-dotenv,避免敏感信息被硬编码到代码中相关推荐

  1. 基于python的九轴惯性传感器的数据预处理代码-中值滤波实验

    ** 基于python的九轴惯性传感器的数据预处理代码-中值滤波实验 ** import random import numpy as np import pandas as pd import sc ...

  2. 硬编码 java_Java编程中的硬编码问题

    在计算机程序或文本编辑中,硬编码是指将可变变量用一个固定值来代替的方法. 用这种方法编译后,如果以后需要更改此变量就非常困难了. 大部分程序语言里,可以将一个固定数值定义为一个标记,然后用这个特殊标记 ...

  3. python如何提高性能_python – 如何在这个短代码中提高numpy性能...

    我试图了解为什么我的一个python脚本比gfortran慢了约4倍,我必须这样做: import numpy as np nvar_x=40 nvar_y=10 def fn_tst(x): for ...

  4. Python加密有敏感信息的Word/Excel等文件

    ① 目的 电脑使用时间长,保存了极多的WORD与EXCEL文件 文件版本不同(.doc .docx .xls .xlsx -) 文件内保存有重要的身份信息(身份证号.手机号-) 要求对word和exc ...

  5. python 电影导演演员信息 演员参演电影字典 关系中最好的n个演员

    python演员关系分析 一.演员关系分析 实验目的: 熟悉Python扩展库openpyxl的安装与使用. 了解Execl文件结构与数据组织形式: 熟练掌握集合运算以及集合常用方法: 实验内容: 随 ...

  6. WebRTC IOS视频硬编码流程及其中传递的CVPixelBufferRef

    WebRTC中默认摄像头采集: RTCCameraVideoCapturer: src/sdk/objc/components/capturer/RTCCameraVideoCapturer.m- ( ...

  7. 浅谈“敏感信息泄露“

    一:漏洞名称: 敏感信息泄露 描述: 敏感数据包括但不限于:口令.密钥.证书.会话标识.License.隐私数据(如短消息的内容).授权凭据.个人数据(如姓名.住址.电话等)等,在程序文件.配置文件. ...

  8. 风炫安全WEB安全学习第四十四节课 敏感信息泄漏

    第四十四节课 敏感信息泄漏 敏感信息泄漏 0x01 漏洞简介 敏感数据包括但不限于:口令.密钥.证书.会话标识.License.隐私数据(如短消息的内容).授权凭据.个人数据(如姓名.住址.电话等)等 ...

  9. Android安全开发之浅谈密钥硬编码

    Android安全开发之浅谈密钥硬编码 作者:伊樵.呆狐@阿里聚安全 1 简介 在阿里聚安全的漏洞扫描器中和人工APP安全审计中,经常发现有开发者将密钥硬编码在Java代码.文件中,这样做会引起很大风 ...

最新文章

  1. JVM - 一个案例反推不同JDK版本的intern机制以及intern C++源码解析
  2. Problems you may meet
  3. 90题细品吴恩达《机器学习》,感受被刷题支配的恐惧
  4. html5 vr效果,HTML5 Three.js 虚拟现实小实验(VR Experiment)
  5. pytorch 测试每一类_2D-UNet脑胶质瘤分割BraTs + Pytorch实现
  6. 【Elasticsearch】Curator 从入门到实战
  7. UITableView 编辑和删除行
  8. 小甲鱼Python第十九讲课后习题
  9. Linux htop工具使用详解
  10. SQL Server 获取日期是星期周几(默认从周日开始到周六 1-7)
  11. paip.php-gtk 桌面程序 helloworld总结
  12. 从放弃迅雷和IDM到自己开发下载工具 1
  13. Java详解:Java疯狂讲义第五版下载
  14. oracle中文chr,Oracle中chr(10) chr(9)和chr(13)用法和意义
  15. unity通过点击按钮获取手机验证码
  16. 【转】阿里云主机购买使用教程
  17. 跳动的爱心代码--李峋爱心代码(完整源码)
  18. 【RPO技巧拓展】————3、IIS和.Net应用程序中的非根相对路径覆盖(RPO)
  19. OPENGL三维场景搭建、漫游、交互
  20. 高新技术企业减税新增政策

热门文章

  1. 如何学好计算机专业?
  2. arm linux 内核启动,Linux(ARM)内核启动地址
  3. js 默认的参数、可变的参数、变量作用域
  4. Hbase常用操作(增删改查)
  5. Android - View绘图原理总结
  6. HBase总结(十三)HBase Shell 常用命令及例子
  7. 安装python及web.py
  8. 网络流之——最小费用最大流
  9. 铁轨问题 判断是否为出栈顺序
  10. sql复杂查询语句总结