Python Django 入門トップページ


カスタムユーザ認証

  1. プロジェクトの概要
  2. プロジェクトの作成と初期設定
  3. Users アプリケーションの作成と有効化
  4. 認証にカスタムユーザモデルを利用する
  5. モデルの作成
  6. マイグレーション
  7. ユーザの登録
  8. 管理ユーザの登録
  9. 管理サイトの作成
  10. Comments アプリケーションの作成
  11. ページ雛形の作成
  12. ログイン・ログアウトの実装
  13. Navbar の設置
  14. Comments アプリケーションのユーザ認証
  15. ユーザ一覧ページ
  16. ユーザ詳細情報の表示
  17. ユーザ情報の更新
  18. パスワードの変更
  19. Gmail 2段階認証の設定とアプリパスワードの取得
  20. メールの設定と送信
  21. パスワードのリセット
  22. ユーザ登録機能の実装
  23. ユーザ登録時に氏名も登録
  24. ユーザ登録時にメールアドレスも登録
  25. ユーザ登録してもログインできないように
  26. ユーザ登録後にメールを送信
  27. メール検証によるアカウントの有効化
  28. トークン有効期限の変更
  29. ログアウト後に top へリダイレクト
  30. 検証メールの再送信
  31. 未検証ユーザのログインエラーメッセージ
  32. メールに有効期限を表示
  33. フラッシュメッセージの変更
  34. 未検証ユーザのパスワードリセット

カスタムユーザ認証

ログアウト後に top へリダイレクト

前のページでは settings.py を編集してトークンの有効期限を変更したが,同じように,ログアウト後にリダイレクトされる URL を変更してみよう.

custom_auth_project/settings.py
LOGOUT_REDIRECT_URL = '/'

ログアウトの処理にフラッシュメッセージを追加します.なおテンプレート名を指定する必要がなくなったので,削除しておきます.

/users/views.py
class LogoutView(SuccessURLAllowedHostsMixin, TemplateView):
    """
    Log out the user and display the 'You are logged out' message.
    """

    next_page = None
    redirect_field_name = REDIRECT_FIELD_NAME
    # template_name = "registration/logged_out.html"
    # template_name = "users/logged_out.html"
    extra_context = None

    @method_decorator(never_cache)
    def dispatch(self, request, *args, **kwargs):
        messages.success(request, 'ログアウトしました')
        auth_logout(request)
        next_page = self.get_next_page()
        if next_page:
            # Redirect to this page until the session has been cleared.
            return HttpResponseRedirect(next_page)
        return super().dispatch(request, *args, **kwargs)

「ログアウトしました」というページが不要になったので HTML ファイルを削除します.このとき,Git の管理下からも削除するために Git のコマンドで削除します.

(py39) C:\Users\lecture\Documents\django\custom_auth_project>git rm users\templates\users\logged_out.html ⏎
rm 'users/templates/users/logged_out.html'

(py39) C:\Users\lecture\Documents\django\custom_auth_project>

目次に戻る