1. 程式人生 > 實用技巧 >272 Flask學習【第01篇】:Flask介紹

272 Flask學習【第01篇】:Flask介紹

一、Flask介紹(輕量級的框架,非常快速的就能把程式搭建起來)

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

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

預設情況下,Flask 不包含資料庫抽象層、表單驗證,或是其它任何已有多種庫可以勝任的功能。然而,Flask 支援用擴充套件來給應用新增這些功能,如同是 Flask 本身實現的一樣。眾多的擴充套件提供了資料庫整合、表單驗證、上傳處理、各種各樣的開放認證技術等功能。Flask 也許是“微小”的,但它已準備好在需求繁雜的生產環境中投入使用。

- 和django的比較
    django:無socket,依賴第三方模組wsgi,中介軟體,路由系統(CBV,FBV),檢視函式,ORM。cookie,session,Admin,Form,快取,訊號,序列化。。
    Flask:無socket,中介軟體(擴充套件),路由系統,檢視(CBV)、第三方模組(依賴jinja2),cookie,session弱爆了

二、簡單使用

1、安裝

pip3 install flask
#Flask依賴一個實現wsgi協議的模組:werkzeug
from werkzeug.wrappers import Request, Response

@Request.application
def hello(request):
return Response('Hello World!')

if name == 'main':
from werkzeug.serving import run_simple
run_simple(
'localhost', 4000, hello)

from flask import
Flask app = Flask(__name__)

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

if name == 'main':
app.run()

練習

from flask import Flask,render_template,request,redirect,session
app = Flask(__name__)
app.secret_key = "sdsfdsgdfgdfgfh"

def wrapper(func):
def inner(args,**kwargs):
if not session.get("user_info"):
return redirect("/login")
ret
= func(
args,**kwargs)
return ret
return inner

@app.route("/login",methods=["GET","POST"])
def login():
if request.method"GET":
return render_template("login.html")
else:
# print(request.values) #這個裡面什麼都有,相當於body
username = request.form.get("username")
password
= request.form.get("password")
if username
"haiyan" and password=="123":
session[
"user_info"] = username
# session.pop("user_info") #刪除session
return redirect("/index")
else:
# return render_template("login.html",**{"msg":"使用者名稱或密碼錯誤"})
return render_template("login.html",msg="使用者名稱或者密碼錯誤")

@app.route("/index",methods=["GET","POST"])
@wrapper
def index():
# if not session.get("user_info"):
# return redirect("/login")
return render_template("index.html")

if name == 'main':
app.run(debug
=True)

儲存session的資料存到了瀏覽器上,
  - 優點:減輕了服務端的壓力
  - 缺點:不安全

三、排錯

1、當你點選提交出現這樣的錯

解決方案

@app.route("/login",methods=["GET","POST"])

2、設定session的時候

解決方法:設定祕鑰

app.secret_key = "sdsfdsgdfgdfgfh"

附加: