当前位置: 首页 > ds >正文

Django-environ 入门教程

Django-environ 入门教程

Django-environ 是一个帮助 Django 项目管理环境变量的库,它可以简化 .env
文件的管理,并集中处理敏感配置如数据库连接、API 密钥等。

安装

首先安装 django-environ:

pip install django-environ

基本配置

1. 创建 .env 文件

在 Django 项目的根目录(manage.py 同级)创建 .env 文件:

DEBUG=on
SECRET_KEY=your-secret-key
DATABASE_URL=psql://user:password@127.0.0.1:8458/database
SQLITE_URL=sqlite:///my-local-sqlite.db
CACHE_URL=memcache://127.0.0.1:11211,127.0.0.1:11212,127.0.0.1:11213
REDIS_URL=rediscache://127.0.0.1:6379/1?client_class=django_redis.client.DefaultClient&password=secret
2. 修改 settings.py

在 Django 的 settings.py 文件中进行以下修改:

import environ# 初始化 environ
env = environ.Env()# 从 .env 文件读取环境变量
environ.Env.read_env()# 使用环境变量
SECRET_KEY = env('SECRET_KEY')
DEBUG = env('DEBUG')# 数据库配置
DATABASES = {'default': env.db(),'extra': env.db('SQLITE_URL', default='sqlite:////tmp/my-tmp-sqlite.db'),
}# 缓存配置
CACHES = {'default': env.cache(),'redis': env.cache('REDIS_URL'),
}

高级用法

类型转换

django-environ 会自动转换类型:

DEBUG = env.bool('DEBUG', default=False)  # 转换为布尔值
ALLOWED_HOSTS = env.list('ALLOWED_HOSTS', default=['localhost'])  # 转换为列表
PORT = env.int('PORT', default=8000)  # 转换为整数
默认值和必填项
# 如果没有设置会抛出异常
REQUIRED_SETTING = env('REQUIRED_SETTING')# 使用默认值
OPTIONAL_SETTING = env('OPTIONAL_SETTING', default='default_value')
使用 .env 以外的文件
在这里插入代码片
env = environ.Env()
environ.Env.read_env('/path/to/other/.env')  # 指定其他路径的 .env 文件
在模板中使用环境变量
# settings.py
TEMPLATES = [{# ...'OPTIONS': {'context_processors': [# ...'django.template.context_processors.request','yourapp.context_processors.expose_env',],},},
]# yourapp/context_processors.py
from django.conf import settingsdef expose_env(request):return {'ENV_DEBUG': settings.DEBUG,'ENV_VERSION': settings.VERSION,}
http://www.xdnf.cn/news/16692.html

相关文章:

  • 镜像源加速下载
  • 在WSL中配置VS Code C++开发环境完整教程
  • linux中简易云盘系统项目实战:基于 TCP协议的 Socket 通信、json数据交换、MD5文件区别与多用户文件管理实现
  • 《C++初阶之STL》【list容器:详解 + 实现】
  • 低速信号设计之 UART 篇
  • 鸿蒙网络编程系列59-仓颉版TLS回声服务器示例
  • 如何迁移gitlab到另一台服务器
  • 图像认知与OpenCV | Day5:图像预处理(4)
  • C++20协程实战:高效网络库、手机终端、多媒体开发开发指南
  • Javaweb - 13 - AJAX
  • Qt|槽函数耗时操作阻塞主界面问题
  • Chrome 提示 “此扩展程序不再受支持”(MacOS/Windows)
  • WindowsAPI|每天了解几个winAPI接口之网络配置相关文档Iphlpapi.h详细分析六
  • C++异常捕获:为何推荐按引用(by reference)捕获?
  • 华为昇腾芯片:多模态模型国产化的硬核突破
  • Ext JS极速项目之 Coworkee
  • ETH 交易流程深度技术详解
  • Linux进程概念(五)进程地址空间
  • 凸优化:凸函数的一些常用性质
  • 低成本嵌入式Linux开发方案:通过配置文件实现参数设置
  • 基于黑马教程——微服务架构解析(二):雪崩防护+分布式事务
  • 如何在 Ubuntu 24.04 或 22.04 Linux 上安装和使用 NoMachine
  • JavaScript 回调函数讲解_callback
  • 力扣7:整数反转
  • golang--通道和锁
  • 做了一款小而美的本地校验器
  • jimfs:Java内存文件系统,脱离磁盘IO瓶颈利器
  • 使用Docker在Rocky Linux 9.5上在线部署LangFlow
  • 【力扣热题100】哈希——两数之和
  • 基于深度学习的医学图像分析:使用3D CNN实现肿瘤检测