ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
基本: from django.conf import settings
Django のアプリ内から settings.py の値を参照する標準的な方法:
from django.conf import settings
from django.views.generic import View
class TestView(View):
def get(self, request):
# 標準設定
secret = settings.SECRET_KEY
debug = settings.DEBUG
timezone = settings.TIME_ZONE
# カスタム定数(settings.py に書いたもの)
api_key = settings.MY_API_KEY
max_users = settings.MAX_USERS
return JsonResponse({
'debug': debug,
'timezone': timezone,
})
settings.py のカスタム定数
# myproject/settings.py
import os
from pathlib import Path
BASE_DIR = Path(__file__).resolve().parent.parent
# 標準的な Django 設定
SECRET_KEY = os.environ.get('SECRET_KEY', 'dev-secret-key')
DEBUG = os.environ.get('DEBUG', 'False') == 'True'
ALLOWED_HOSTS = os.environ.get('ALLOWED_HOSTS', '').split(',')
# カスタム定数(命名規則: 大文字 + アンダースコア)
MY_API_KEY = os.environ.get('MY_API_KEY', '')
MAX_USERS = int(os.environ.get('MAX_USERS', 100))
PAYMENT_PROVIDER = 'stripe'
EMAIL_SENDER_NAME = 'My Service'
# 辞書形式の定数
PRICING = {
'basic': 1000,
'premium': 5000,
}
環境変数経由が推奨
機密情報・環境ごとに変わる値は環境変数経由で読むのが定石:
# settings.py
import os
# シンプルな環境変数
SECRET_KEY = os.environ['SECRET_KEY'] # 必須(未設定で例外)
# デフォルト値付き
DEBUG = os.environ.get('DEBUG', 'False') == 'True'
# python-dotenv で .env 読み込み(推奨)
from dotenv import load_dotenv
load_dotenv()
# django-environ で型付き取り出し(更に推奨)
import environ
env = environ.Env(DEBUG=(bool, False))
environ.Env.read_env(BASE_DIR / '.env')
SECRET_KEY = env('SECRET_KEY')
DEBUG = env('DEBUG')
DATABASE_URL = env.db('DATABASE_URL') # 自動で DATABASES dict に変換
ALLOWED_HOSTS = env.list('ALLOWED_HOSTS', default=[])
MAX_USERS = env.int('MAX_USERS', default=100)
環境別 settings の分割
開発・ステージング・本番で設定が大きく変わる場合、settings をモジュール分割します:
# myproject/settings/__init__.py
# 環境変数 DJANGO_SETTINGS_MODULE で切替
# myproject/settings/base.py - 共通設定
SECRET_KEY = ...
INSTALLED_APPS = [...]
# myproject/settings/dev.py - 開発
from .base import *
DEBUG = True
DATABASES = {'default': {'ENGINE': 'sqlite3', ...}}
# myproject/settings/prod.py - 本番
from .base import *
DEBUG = False
DATABASES = {'default': {'ENGINE': 'postgresql', ...}}
# manage.py や wsgi.py で
# os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'myproject.settings.prod')
テンプレートからの参照
Django テンプレートで settings の値を使うには context_processor を経由:
# myapp/context_processors.py
from django.conf import settings
def site_settings(request):
return {
'SITE_NAME': settings.SITE_NAME,
'SUPPORT_EMAIL': settings.SUPPORT_EMAIL,
'DEBUG': settings.DEBUG,
}
# settings.py の TEMPLATES に追加
TEMPLATES = [
{
...,
'OPTIONS': {
'context_processors': [
...,
'myapp.context_processors.site_settings', # ★ 追加
],
},
},
]{# テンプレートで参照可能に #}
{{ SITE_NAME }} - About
サポート: {{ SUPPORT_EMAIL }}
{% if DEBUG %}
{% endif %}
テスト時の settings 上書き
from django.test import TestCase, override_settings
class MyTest(TestCase):
@override_settings(MY_API_KEY='test-key', DEBUG=True)
def test_something(self):
from django.conf import settings
self.assertEqual(settings.MY_API_KEY, 'test-key')
# この test 内だけ MY_API_KEY が上書きされる
# クラス全体に適用
@override_settings(DEBUG=True)
class AllTests(TestCase):
...
実行時に settings を読み込む / 変更する
動作中の settings 値を変更してはいけない(read-only 設計):
# ❌ NG: 実行時に書き換える
settings.MY_API_KEY = 'new-value' # 副作用が予測できなくなる
# ✅ OK: settings は読み取り専用、別の状態管理を使う
# - DB の Settings モデル
# - Cache (Redis) に保存
# - 環境変数 + プロセス再起動
関連
- django-environ: 環境変数を型付きで読む推奨パッケージ
- python-dotenv:
.envファイル読み込み - django-constance: 管理画面から動的に設定を変更できる
- django-configurations: クラスベースの settings 分割
- 本番でのデバッグ情報露出禁止:
DEBUG=Falseでないと SECRET_KEY 等が漏れる
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページ
子ページはありません
同階層のページ
- 環境構築とプロジェクト/アプリの作成
- MVC(MVT)のそれぞれの使い方と説明
- データベースへの接続と操作
- Django Administration
- git管理
- エラー一覧
- バージョンの確認方法
- ログ出力方法
- SQLのログ出力方法
- ログのローテート設定
- settings.pyの定数にアクセスする方法
- 本番環境へのインストールとアプリのデプロイ(apache編)
- 本番環境へのインストールとアプリのデプロイ(nginx編)
- djangoアプリの本番の開始URLを変更する
- 静的(static)ファイルの置き場所と読み込み(画像、css、js )
- CSRFトークンをAjaxで使用する方法
- ajaxの使用例(POST編)
- ファイルのアップロードとファイルの名前
- クイックスタート/チュートリアル
- ログイン機能
- テンプレート側のログイン判定
- ビュー側のログイン判定
- 管理者ユーザーの作成/判定と管理画面
- モデルのjson化とレスポンス
- runserverでポートを指定する方法
- cronによるバッチ実行
- テンプレートで利用する共通のcontextを定義する方法
- プログラムが本番サーバーで反映されない場合の対処法
- APIの作成
- cron用コマンド・ファイルの作成
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?