Flask

簡介

Flask是一個基於Python開發而且依賴jinja2模板和Werkzeug WSGI服務的一個微型框架,對於Werkzeug本質是Socket服務端,其用於接收http請求並對請求進行預處理,而後觸發Flask框架,開發人員基於Flask框架提供的功能對請求進行相應的處理,並返回給用戶,若是要返回給用戶複雜的內容時,須要藉助jinja2模板來實現對模板的處理,即:將模板和數據進行渲染,將渲染後的字符串返回給用戶瀏覽器。html

「微」(micro) 並不表示你須要把整個 Web 應用塞進單個 Python 文件(雖然確實能夠 ),也不意味着 Flask 在功能上有所欠缺。微框架中的「微」意味着 Flask 旨在保持核心簡單而易於擴展。Flask 不會替你作出太多決策——好比使用何種數據庫。而那些 Flask 所選擇的——好比使用何種模板引擎——則很容易替換。除此以外的一切都由可由你掌握。如此,Flask 能夠與您珠聯璧合。python

默認狀況下,Flask 不包含數據庫抽象層、表單驗證,或是其它任何已有多種庫能夠勝任的功能。然而,Flask 支持用擴展來給應用添加這些功能,如同是 Flask 自己實現的同樣。衆多的擴展提供了數據庫集成、表單驗證、上傳處理、各類各樣的開放認證技術等功能。Flask 也許是「微小」的,但它已準備好在需求繁雜的生產環境中投入使用。數據庫

基本使用

from flask import Flask

app = Flask(__name__)


@app.route('/')
def hello_world():
    return 'Hello World!'


if __name__ == '__main__':
    app.run()  

路由系統

#!/usr/bin/env python
# -*- coding: utf-8 -*-
__author__ = 'Wu'

from flask import Flask

app = Flask(__name__)



# @app.route('/index')
def index():
    return 'Index'


def login():
    return 'Login'


app.add_url_rule('/index', 'index', index, methods=['GET'])
app.add_url_rule('/login', 'login', login, methods=['GET'])

if __name__ == '__main__':
    app.run()

源碼實現: flask

def _endpoint_from_view_func(view_func):
    
    assert view_func is not None, 'expected view func if endpoint ' 'is not provided.'
    return view_func.__name__  # endpoint等於視圖函數的名字

def add_url_rule(self, rule, endpoint=None, view_func=None, **options):
    if endpoint is None:    # 2. 若是endpoint爲None

        endpoint = _endpoint_from_view_func(view_func)  # 3. endpoint等於。。。
    options['endpoint'] = endpoint
    methods = options.pop('methods', None)

def route(self, rule, **options):
    def decorator(f):
        endpoint = options.pop('endpoint', None)  # 1.若是不設置endpoint則爲None
        self.add_url_rule(rule, endpoint, f, **options)  # flask路由的本質就是調用self.add_url_rule
        return f

    return decorator

CBV

Django中處理請求的方式有FBV和CBV兩中,其實Flask中也支持CBV,它的CBV和Django的相似。瀏覽器

#!/usr/bin/env python
# -*- coding: utf-8 -*-
__author__ = 'Wu'
 
from flask import Flask, views
 
app = Flask(__name__)
 
 
def auth(func):
    def inner(*args, **kwargs):
        print('Before')
        result = func(*args, **kwargs)
        print('After')
        return result
    return inner
 
 
class LoginView(views.MethodView):
    methods = ['GET', 'POST']
    decorators = [auth, ]  # 裝飾器
 
    def get(self):
        return 'CBV GET'
 
    def post(self):
        return 'CBV POST'
 
 
app.add_url_rule('/login', view_func=LoginView.as_view(name='login'))  # name=endpoint
 
 
if __name__ == '__main__':
    app.run()
View Code 

請求擴展

#!/usr/bin/env python
# -*- coding: utf-8 -*-
__author__ = 'Wu'

from flask import Flask, Request, render_template
 
app = Flask(__name__, template_folder='templates')
app.debug = True
 
 
@app.before_first_request
def before_first_request1():
    print('before_first_request1')
 
 
@app.before_first_request
def before_first_request2():
    print('before_first_request2')
 
 
@app.before_request
def before_request1():
    Request.nnn = 123
    print('before_request1')
 
 
@app.before_request
def before_request2():
    print('before_request2')
 
 
@app.after_request
def after_request1(response):
    print('before_request1', response)
    return response
 
 
@app.after_request
def after_request2(response):
    print('before_request2', response)
    return response
 
 
@app.errorhandler(404)
def page_not_found(error):
    return 'This page does not exist', 404
 
 
@app.template_global()
def sb(a1, a2):
    return a1 + a2
 
 
@app.template_filter()
def db(a1, a2, a3):
    return a1 + a2 + a3
 
 
@app.route('/')
def hello_world():
    return render_template('hello.html')
 
 
if __name__ == '__main__':
    app.run()
View Code

基於請求擴展實現session認證

#!/usr/bin/env python
# -*- coding: utf-8 -*-
__author__ = 'Wu'

from flask import Flask, render_template, request, redirect, session
 
app = Flask(__name__)
app.debug = True
app.secret_key = 'df$d5!5fe-43'
 
 
@app.before_request
def process_request():
    if request.path == '/login':
        return None
    user = session.get('user')
    if not user:
        return redirect('/login')
 
 
@app.route('/index')
def index():
 
    return render_template('index.html')
 
 
@app.route('/login', methods=['GET', 'POST'])
def login():
    if request.method == 'GET':
        return render_template('login.html')
 
    else:
        username = request.form.get('username')
        password = request.form.get('password')
        if username == 'test' and password == '123456':
            session['user'] = username
            return redirect('/index')
        else:
            return '用戶名或密碼錯誤'
 
 
if __name__ == '__main__':
    app.run()
View Code
相關文章
相關標籤/搜索