>  기사  >  백엔드 개발  >  Flask 프로젝트 구조 이해

Flask 프로젝트 구조 이해

Guanhui
Guanhui앞으로
2020-06-13 10:02:202608검색

Flask 프로젝트 구조 이해

Preface

먼저, virtualenv를 사용하여 프로젝트를 격리합니다. 예를 들어, 우리는 설문조사 애플리케이션(설문조사 앱)을 개발하고 싶습니다.

mkdir poll_app
cd poll_app
virtualenv .
source bin/activate

일반적으로 사용되는 Python 라이브러리

데이터베이스가 필요한 애플리케이션을 개발 중입니다. 그래서 저는 항상 플라스크_스크립트와 플라스크_마이그레이션 라이브러리를 사용합니다. 나는 Flask의 CLI 도구를 좋아하지 않습니다.

Flask-스크립트: https://flask-script.readthedocs.io/en/latest/

Flask-Migrate: https://flask- migration.readthedocs.io/en/latest/

Django와 유사하게 루트 폴더에 prepare.py라는 Python 파일을 만들었습니다. 예:

from MYAPP.data.models import db
from MYAPP import app
from flask_script import Manager
from flask_migrate import Migrate, MigrateCommand
db.init_app(app)
migrate = Migrate(app, db)
manager = Manager(app)
manager.add_command('db', MigrateCommand)
if __name__ == "__main__":
    manager.run()

그런 다음 데이터에 대해 다음 작업을 수행할 수 있습니다.

python manage.py db init # --> init migrations
python manage.py db migrate # --> migrate models
python manage.py db upgrade # --> apply changes
python manage.py db --help # --> :)

기본 애플리케이션 파일

새 프로젝트를 생성할 때 루트 폴더에 app.py 파일을 생성하면 이렇게 바뀌게 됩니다.

from MYAPP import app
# To do: This place will change later
config = {
    "development": "config.Development"
}
if __name__ == "__main__":
    app.config.from_object(config["development"])
    app.run()

Configuration File

루트 폴더에 config.py라는 구성 파일도 생성했습니다.

class BaseConfig(object):
    """ Base config class. This fields will use by production and development server """
    ORIGINS = ["*"] # for api calls
    SECRET_KEY = 'YOUR SECRET KEY'
class Development(BaseConfig):
    """ Development config. We use Debug mode """
    PORT = 5000
    DEBUG = True
    TESTING = False
    ENV = 'dev'
# Currently we only have development config.
# If you have production, you will need to pass it to here.
config = {
    'development': 'config.Development'
}
def configure_app(app):
    """ 
        App configuration will be here. 
        Parameters
        ----------
        app : Flask
            app instance
    """
    app.config.from_object(config['development'])

폴더 구조

루트 디렉터리에 폴더를 만들고 이름을 om_core로 지정한 다음 api와 data라는 두 개의 새 폴더를 홀수로 만듭니다.

api 파일은 애플리케이션 로직과 라우팅을 저장합니다. 예를 들어, API에 user라는 폴더를 만들었습니다.

다른 Api 레이어와 마찬가지로 사용자 폴더에 init.py 및 Controllers.py라는 두 개의 파일을 생성합니다. Controllers.py(컨트롤러 파일)은 다음과 같아야 합니다.

from flask import Blueprint, jsonify, request
from MYAPP.data.models import db, User
user = Blueprint('user', __name__)
@user.route('/', methods=['GET'])
def get_users():
    return jsonify({ "message": "Hi user :)"})
@user.route(&#39;/<int:id>&#39;, methods=[&#39;GET&#39;])
def users(id):
    return jsonify({ "id": id })

저는 항상 블루프린트를 사용합니다.

data 폴더에는 일부 모델이 저장됩니다. 예를 들어 models.py라는 파일을 만들었습니다.

from flask_sqlalchemy import SQLAlchemy
from MYAPP import app
# We didn&#39;t pass app instance here.
db = SQLAlchemy()
class User(db.Model):
    """ Model for user management """
    id = db.Column(db.Integer, primary_key=True)
    email = db.Column(db.String(100), unique=True)
    password = db.Column(db.String(100))
    name = db.Column(db.String(100))
    surname = db.Column(db.String(100))
    active = db.Column(db.Boolean(), default=True)
    created_at = db.Column(db.DateTime, default=db.func.now())
    updated_at = db.Column(db.DateTime, default=db.func.now())
    def __init__(self, email, password, name, surname, active, created_at, updated_at):
        self.email = email
        self.password = password
        self.name = name
        self.surname = surname
        self.active = active
        self.created_at = created_at
        self.updated_at = updated_at

om_core 폴더로 돌아가겠습니다. Api 레이어를 엔드포인트로 사용하기 위해 init .py라는 파일을 만들었습니다.

from flask import Flask
from flask_cors import CORS
from config import BaseConfig
from config import configure_app
app = Flask(__name__)
from MYAPP.api.user.controllers import user
""" Corst settings will be here. We maybe use this endpoint later. """
cors = CORS(app, resources={
    r&#39;/api/*&#39;: {
        &#39;origins&#39;: BaseConfig.ORIGINS
    }
})
configure_app(app)
app.url_map.strict_slashes = False
app.register_blueprint(user, url_prefix=&#39;/api/users&#39;)

위 코드에서는 Flask-CORS를 사용하여 다양한 출처의 요청을 허용했습니다. 다른 출처의 요청을 허용하지 않으려는 경우에는 필요하지 않습니다.

전체 프로젝트 구조의 스크린샷

스크린샷은 다음과 같습니다:

Flask 프로젝트 구조 이해

추천 튜토리얼: "Python Tutorial"

위 내용은 Flask 프로젝트 구조 이해의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 learnku.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제