ホームページ >バックエンド開発 >Python チュートリアル >Flask-Admin と SQLAlchemy: Python で管理バックエンド システムを構築するためのベスト プラクティス

Flask-Admin と SQLAlchemy: Python で管理バックエンド システムを構築するためのベスト プラクティス

WBOY
WBOYオリジナル
2023-06-17 19:17:091791ブラウズ

インターネットの発展に伴い、管理バックエンドシステムの構築に注力する企業が増えています。管理バックエンド システムは、企業のさまざまな複雑なビジネス データとシステム構成の管理を支援し、企業の業務効率を向上します。 Python は、バックエンド システムの開発と管理に非常に適した人気のあるプログラミング言語です。 Python では、Flask-Admin と SQLAlchemy の 2 つの非常に重要なツールがあり、これらを組み合わせることで、優れた管理バックエンド システムを構築できます。

Flask-Admin は、Flask フレームワークに基づく拡張機能として、完全な管理バックエンド システムを迅速に構築できます。一方、SQLAlchemy は、データベースとの対話を大幅に簡素化する Python ORM フレームワークです。この記事では、Flask-Admin と SQLAlchemy を使用して管理バックエンド システムを構築する方法を紹介し、読者の参考となるベスト プラクティスを提供します。

まず、必要な依存ライブラリをインストールする必要があります。 Flask-Admin と SQLAlchemy は両方とも pip install コマンドを通じてインストールできます。インストールが完了したら、コードの記述を開始できます。

Flask-Admin と SQLAlchemy を使用するプロセスでは、次の手順を完了する必要があります:

  1. Flask アプリケーションの作成
  2. SQLAlchemy の初期化
  3. データベース モデルの作成
  4. Flask-Admin ビューの作成

以下、これらの手順を 1 つずつ紹介します。

Flask アプリケーションの作成

まず、Flask アプリケーションを作成する必要があります。このアプリケーションでは、データベース接続、静的ファイル、テンプレート パスなど、多くの一般的な Flask 構成を完了する必要があります。以下は、一般的な Flask アプリケーション構成情報です:

from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_admin import Admin

app = Flask(__name__)
app.config['SECRET_KEY'] = 'supersecretkey'
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///mydatabase.db'
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False

db = SQLAlchemy(app)

admin = Admin(app, name='My Admin', template_mode='bootstrap3')

この例では、Flask アプリケーションを作成し、SECRET_KEY、データベース接続情報、および Flask-Admin 構成情報を使用して構成しました。このうち、SUPER_SECRET_KEY はプログラムのセキュリティを確保するために実際のキーに置き換える必要があります。さらに、SQLAlchemy ライブラリを使用してデータベースを初期化し、flask_admin ライブラリを使用して管理バックグラウンドを作成しました。これが私たちが踏みたい最初の一歩です。

SQLAlchemy の初期化

次に、SQLAlchemy を使用してデータベースを初期化する必要があります。まず、データベース モデルを定義する必要があります。これは単純なモデルです:

class User(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(80), unique=True, nullable=False)
    email = db.Column(db.String(120), unique=True, nullable=False)

    def __repr__(self):
        return '<User %r>' % self.username

このモデルでは、ID、ユーザー名、電子メール アドレスを含むユーザー モデルを定義します。 repr メソッドを使用してユーザーの出力形式を定義します。実際のニーズに応じて、ここにさらにフィールドを追加できます。

Flask-Admin ビューの作成

モデルを定義することにより、モデルをデータベースにマッピングしました。次に、Flask-Admin を使用して管理バックエンド ページを作成する必要があります。

from flask_admin.contrib.sqla import ModelView

admin.add_view(ModelView(User, db.session))

この例では、Flask-Admin の ModelView クラスを使用して User モデルを含む管理ページを作成し、それを前に初期化した Flask-Admin オブジェクトに追加します。このページでは、多くのコードを記述することなく、ユーザーを簡単に作成、変更、削除できます。

ベスト プラクティス

基本的な構成情報を紹介しましたが、実際に管理バックエンド システムを構築する場合は、次のベスト プラクティスにも注意する必要があります。

  1. パスワード セキュリティ

これは明らかな点かもしれませんが、パスワードのセキュリティは真剣に考慮する必要があります。ユーザーを作成するときは、ソルティングや暗号化などの戦略を通じてパスワードのセキュリティを確保する必要があります。

  1. ログイン検証

管理バックエンド システムは大量の機密データを公開するため、ログイン検証メカニズムを実装する必要があります。 Flask は、ユーザーのログインと認証を処理するための Flask-Login ライブラリを提供しており、このプロセスを大幅に簡素化できます。

  1. テンプレートの美化

Flask-Admin はデフォルトのテンプレートのセットを提供しますが、これはそれらをカスタマイズできないという意味ではありません。 CSS および JavaScript ファイルを変更することで、ページの外観をカスタマイズして、ブランドのイメージやスタイルにさらに適合させることができます。

概要

Flask-Admin と SQLAlchemy を使用すると、強力な管理バックエンド システムを迅速に構築できます。このシステムを利用することで、さまざまな複雑なビジネスデータやシステム構成を管理することができ、企業の業務効率を大幅に向上させることができます。この記事で説明されているベスト プラクティスに従うことで、システムのセキュリティ、安定性、使いやすさを確保できます。

以上がFlask-Admin と SQLAlchemy: Python で管理バックエンド システムを構築するためのベスト プラクティスの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。