ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
関数ビューでの判定
最も基本となる書き方。request.user.is_authenticated は属性なのでカッコは不要です(Django 1.10 以降)。
from django.shortcuts import render, redirect
def my_view(request):
if request.user.is_authenticated:
# ログイン済みの処理
return render(request, 'logged_in.html', {'user': request.user})
else:
# 未ログイン時の処理
return redirect('login')
古い書き方との違い
| バージョン | 書き方 | 備考 |
|---|---|---|
| Django 1.9 以前 | request.user.is_authenticated() | メソッド呼び出し |
| Django 1.10 以降 | request.user.is_authenticated | 属性(プロパティ) |
@login_required デコレータ
未ログイン時に自動でログインページへリダイレクトしたい場合はデコレータが便利です。
from django.contrib.auth.decorators import login_required
@login_required
def my_view(request):
# ここに来た時点でログイン済みが保証される
return render(request, 'dashboard.html')
# ログイン URL を明示
@login_required(login_url='/custom-login/')
def my_view2(request):
...
未ログインの場合、settings.LOGIN_URL(デフォルト /accounts/login/)にリダイレクトされ、ログイン成功後は元のページに戻ります。
クラスベースビューでの判定 (LoginRequiredMixin)
from django.contrib.auth.mixins import LoginRequiredMixin
from django.views.generic import TemplateView
class DashboardView(LoginRequiredMixin, TemplateView):
template_name = 'dashboard.html'
login_url = '/login/' # 省略時は settings.LOGIN_URL
redirect_field_name = 'next' # 戻り先パラメータ名
注意: 多重継承の順序は LoginRequiredMixin を左側に書きます。
テンプレート側での判定
{% if user.is_authenticated %}
<p>ようこそ、{{ user.username }} さん</p>
<a href="{% url 'logout' %}">ログアウト</a>
{% else %}
<a href="{% url 'login' %}">ログイン</a>
{% endif %}
権限付き判定
単なるログイン有無ではなく「特定権限がある人だけ」にする場合。
from django.contrib.auth.decorators import permission_required, user_passes_test
from django.contrib.auth.mixins import PermissionRequiredMixin, UserPassesTestMixin
# 関数ビュー: 特定 permission
@permission_required('myapp.change_article')
def edit(request, id):
...
# 関数ビュー: 任意条件
@user_passes_test(lambda u: u.is_staff)
def admin_only(request):
...
# クラスビュー
class StaffOnlyView(UserPassesTestMixin, TemplateView):
def test_func(self):
return self.request.user.is_staff
API ビュー (Django REST framework)
from rest_framework.permissions import IsAuthenticated
from rest_framework.views import APIView
class MyApiView(APIView):
permission_classes = [IsAuthenticated]
def get(self, request):
return Response({'user': request.user.username})
判定方法 早見表
| シーン | 使うもの |
|---|---|
| 関数ビューで分岐 | if request.user.is_authenticated: |
| 関数ビューで強制ログイン | @login_required |
| クラスビューで強制ログイン | LoginRequiredMixin |
| テンプレートで表示分岐 | {% if user.is_authenticated %} |
| 権限/属性で絞る | @permission_required / UserPassesTestMixin |
| DRF API | permission_classes = [IsAuthenticated] |
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 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
- 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
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・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
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?