Flask 프레임 워크

Flask는 외부 라이브러리에 거의 의존하지 않는 마이크로 프레임 워크입니다. 매우 가벼운 프레임 워크이며 우리가 원하는 것을 할 수있는 자유를줍니다.

이 장에서는 Python 및 Flask 프레임 워크를 사용하여 프로젝트를 빌드 할 것입니다.

Flask 시작 및 구성

가장 널리 사용되는 Python 라이브러리와 마찬가지로 Flask 패키지는 PPI (Python Package Index)에서 설치할 수 있습니다. 먼저 디렉토리를 생성 해 보겠습니다 (이 장에서는flaskProject) 그런 다음 가상 환경을 생성하고 flaskEnv) 모든 프로젝트 관련 종속성이로드됩니다 (플라스크 포함). 또한 flask-sqlalchemy를 설치하여 flask 애플리케이션이 SQL 데이터베이스와 통신하는 간단한 방법을 가질 수 있습니다.

플라스크를 설치하면 flaskEnv (virtualEnvironment 이름)가 아래와 같이 표시됩니다.

플라스크로 앱 만들기

플라스크를 설치하면 간단한 "hello application in flask”다음과 같이 코드가 매우 적습니다.

터미널에 다음을 입력하십시오-

$python flaskapp.py

그리고 다음 출력을 볼 수 있습니다.

실행 중 http://127.0.0.1:5000/ 또는 localhost:5000

다음은 예제 코드에서 수행 한 작업에 대한 설명입니다.

  • 먼저 Flask 클래스 라이브러리를 가져옵니다. 이 클래스의 인스턴스는 WSGI 앱입니다.

  • 둘째,이 클래스의 인스턴스를 만듭니다. 애플리케이션 패키지 또는 모듈 이름은 첫 번째 인수입니다. 플라스크는 정적 파일, 템플릿 및 기타 파일을 찾을 위치를 알고 있어야합니다.

  • 다음은 어떤 URL이 메소드 / 함수를 트리거해야하는지 알기 위해 사용하는 route () 데코레이터입니다.

URL 라우팅 생성

URL 라우팅을 사용하면 웹 앱의 URL을 쉽게 기억할 수 있습니다. 이제 몇 가지 URL 경로를 생성합니다.

/hello
/members
/members/name

위의 URL을 기반으로 다음 코드를 작성하고 app.py로 저장할 수 있습니다.

from flask import Flask, render_template

app = Flask(__name__)

@app.route('/')
def index():
   return "Index!"
	
@app.route('/Hello')
def hello():
   return "Hello, World!"
	
@app.route("/members")
def members():
   return "Members"
	
@app.route("/members/<name>/")
def getMember(name):
   return name
	
if __name__ == '__main__':
   app.run(debug=True)
응용 프로그램을 다시 시작할 때 아래 코드 줄을 사용하여 다양한 URL에서 다른 출력을 얻습니다.

$ python app.py

Running on http://localhost:5000/

브라우저에 다음과 같은 출력이 표시됩니다.

다음과 같이 브라우저에서 다른 URL을 시도 할 수 있습니다.

Running on http://localhost:5000/hello, will give the following output −

Running on http://localhost:5000/members, will give −

Running on http://localhost:5000/members/TutorialsPoint/, will give you the following output −

그러나 일반적으로 우리는 (위와 같이) 문자열을 반환하고 싶지 않으며 템플릿을 반환합니다. 이를 위해 우리는 "render_template”을 입력하고 render_template을 일부 입력으로 반환합니다. 그래서 아래 함수는 우리의 일을 할 것입니다.

from flask import render_template
return render_template(‘home.html’)

폴더 템플릿을 만들고 그 안에 home.html 파일을 배치하겠습니다.

다음으로 레이아웃에 대해 설명합니다. 모든 단일 템플릿에 html head 태그와 body 태그를 사용하는 대신 head & body 태그를 포함하고 현재 뷰 또는 현재 템플릿을 래핑하는 레이아웃을 디자인합니다. 이를 위해 하나의 별도 파일을 생성하고layout.html. 여기에 일반 헤드 태그, 본문 태그 및 기타 모든 필수 태그를 넣을 수 있습니다.

다음 코드 줄로 새 layout.html을 만들 수 있습니다.

<!DOCTYPE html>
<html>
   <head>
      <meta charset="utf-8">
      <title>MyFlaskApp</title>
      <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css">
   </head>
   <body>
      {% include 'includes/_navbar.html' %}
      <div class="container">
      {% block body %}
      {% endblock %}
      </div>
      <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js">
      </script>
   </body>
</html>

위의 코드에서는 타이틀 트랙 인 MyFlaskAp를 지정하고 헤드에 css cdn을 사용하고 본문 블록에 javascript를 사용하여 부트 스트랩을 활성화했습니다.

이제 모든 페이지에 대해 navbar를 만들어야합니다. 이를 위해 먼저 include 폴더를 만든 다음 그 안에 _navbar.html 파일을 만들어야합니다. 이제 _navbar.html에서 getbootstrap.com의 표준 스타터 템플릿을 사용해야합니다. 새로 생성 된 _navbar.html 파일은 다음과 같습니다.

그리고이 _navbar.html 파일을 layout.html 파일에 포함 시키십시오.

{% include 'includes/_navbar.html' %}

레이아웃 블록이 있으므로 홈 파일 (home.html)에서이 블록을 확장 할 수 있습니다.

home.html 파일은 아래 코드를 사용하여 만들 수 있습니다.

{% extends 'layout.html' %}
{% block body %}
   <div class="jumbotron text-center">
      <h1>Welcome to FlaskApp</h1>
      <p>This application is built on Flask webframework!</p>
   </div>
{% endblock %}

우리가 flaskapp.py 파일을 실행하려고하면 이것을 사용하면 브라우저에서 아래 출력을 볼 수 있습니다.

이제 활성화하고 싶습니다 (현재 탭이 작동하지 않음). about탭. about 탭에 대한 경로를 만들고 템플릿 파일을 만듭니다.about.html.

appflask.py의 탭 경로는 다음과 같습니다.

about.html 파일에는 다음 내용이 있습니다.

이제 Home 및 About이 처리됩니다. 기사의 경우 루트 디렉토리에 새 파일 (data.py)을 생성 할 수 있습니다. 여기서 데이터를 저장하고 웹 페이지에서 호출합니다.

data.py

def Articles():
   articles = [
      {
         'uid': 1,
         'title': 'Article_One',
         'body': 'Flask, being a microframework, often requires some repetitive step
            to get a third party library working. Because very often these steps could 
            be abstracted to support multiple projects the Flask Extension Registry 
            was created.',
         'Author': 'Rajesh Joshi',
         'Created-on': '07-09-2018'
      },
      {
         'uid': 2,
         'title': 'Article_Two',
         'body': "Flask, being a microframework, often requires some repetitive steps
            to get a third party library working. Because very often these steps could 
            be abstracted to support multiple projects the Flask Extension Registry 
            was created.",
         'Author': 'Rajesh J',
         'Created-on': '07-09-2018'
      },
      {
         'uid': 3,
         'title': 'Article_Three',
         'body': 'Flask, being a microframework, often requires some repetitive steps
            to get a third party library working. Because very often these steps could be
            abstracted to support multiple projects the Flask Extension Registry 
            was created.',
         'Author': 'Joshi Rajesh',
         'Created-on': '07-09-2018'
      }
   ]
   return articles

아래는 articles.html, 각 uid에 대한 기사 제목을 표시합니다.

{% extends 'layout.html' %}
{% block body %}
   <h1>Articles</h1>
   {% for article in articles %}
      <li class="list-group-item">
         <a href="article/{{article.uid}}"> {{article.title}}</a>
      </li>
   {% endfor %}
{% endblock %}

요약하면, Flask는 가볍기 때문에 가장 인기있는 파이썬 웹 프레임 워크 중 하나입니다. 마이크로이지만 확장 가능한 파이썬 웹 프레임 워크입니다. 필요한 기능을 제공함으로써 flask는 간단한 웹 애플리케이션의 개발을 가속화합니다. 따라서 Flask는 작고 덜 복잡한 응용 프로그램에 더 적합합니다.