【Python】Flask框架系列(三):session和cookie操作、get/post请求、钩子函数
生活随笔
收集整理的這篇文章主要介紹了
【Python】Flask框架系列(三):session和cookie操作、get/post请求、钩子函数
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
在Flask中操作session
示例:設置session的過期時間
完整版
舊版
設置session的過期時間
示例
# encoding: utf-8from flask import Flask, session import os from datetime import timedeltaapp = Flask(__name__) app.config['SECRET_KEY'] = os.urandom(24) app.config['PERMANENT_SESSION_LIFETIME'] = timedelta(days=7)# 添加數據到session中 # 操作session的時候,跟操作字典是一樣的 # SECRET_KEY@app.route('/') def hello_world():session['username'] = 'moguiyu'# 如果沒有指定session的過期時間,那么默認是瀏覽器關閉后就自動結束# 如果設置了session的permanent屬性為true,那么過期時間是31天session.permanent = Truereturn "success set username="+str(session.get('username'))@app.route('/get/') def get():return "get username="+str(session.get('username'))if __name__ == '__main__':app.run(debug=True)get和post請求
(關于print不立刻顯示的問題:使用sys.stdout.flush()刷新緩沖區即可)
示例
# encoding: utf-8from flask import Flask, session, request import os import sys from datetime import timedeltaapp = Flask(__name__) app.config['SECRET_KEY'] = os.urandom(24) app.config['PERMANENT_SESSION_LIFETIME'] = timedelta(days=7)# 添加數據到session中 # 操作session的時候,跟操作字典是一樣的 # SECRET_KEY@app.route('/') def hello_world():session['username'] = 'moguiyu'# 如果沒有指定session的過期時間,那么默認是瀏覽器關閉后就自動結束# 如果設置了session的permanent屬性為true,那么過期時間是31天session.permanent = Truereturn "success set username=" + str(session.get('username'))@app.route('/get/') def get():return "get username=" + str(session.get('username'))@app.route('/search/') def search():print request.argssys.stdout.flush()return "request parameters=" + str(request.args)if __name__ == '__main__':app.run(debug=True)簡單的表單提交頁面(post方式)
app.py
g對象的使用
g相當于global,在一次請求中,當前項目的所有地方都可以使用到。
效果示例
源碼
login.html
<!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><title>Title</title> </head> <body> <form action="{{ url_for('login') }}" method="post"><table><tbody><tr><td>用戶名:</td><td><input type="text" name="username" placeholder="請輸入用戶名"></td></tr><tr><td>密碼:</td><td><input type="text" name="password" placeholder="請輸入密碼"></td></tr><tr><td></td><td><input type="submit" placeholder="登錄"></td></tr></tbody></table></form> </body> </html>utils.py
# encoding: utf-8from flask import gdef login_log():print '當前登錄用戶是:%s' % g.usernameapp.py
# encoding: utf-8from flask import Flask, session, request, render_template, g import os import sys from datetime import timedelta from utils import login_logapp = Flask(__name__) app.config['SECRET_KEY'] = os.urandom(24) app.config['PERMANENT_SESSION_LIFETIME'] = timedelta(days=7)# 添加數據到session中 # 操作session的時候,跟操作字典是一樣的 # SECRET_KEY@app.route('/') def hello_world():session['username'] = 'moguiyu'# 如果沒有指定session的過期時間,那么默認是瀏覽器關閉后就自動結束# 如果設置了session的permanent屬性為true,那么過期時間是31天session.permanent = Truereturn "success set username=" + str(session.get('username'))@app.route('/get/') def get():return "get username=" + str(session.get('username'))@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 == 'zhangsan' and password == '123':g.username='zhangsan'login_log()sys.stdout.flush()return render_template('login.html')@app.route('/search/') def search():# 獲取所有參數(字典)print request.args# 獲取某個參數print request.args.get('q')sys.stdout.flush()return "request parameters=" + str(request.args)if __name__ == '__main__':app.run(debug=True)鉤子函數
1、 before_request
before_request可以理解成java中的filter吧。
示例1
示例2(在第7行加一個secretkey,在13行加一個methods=[‘GET’, ‘POST’],圖中忘寫了)
改造:使用g對象(實際使用時,不需要每次都重新獲取session.userid然后和數據庫取出的數據比對,只需要比對一次,如果成功匹配,直接存在g對象中,以后用時直接從g對象取即可)
2、context_prosessor
context_prosessor的使用:示例如下,使用context_prosessor之后就不需要在42行傳參username了
使用實例:登錄后存session
總結
以上是生活随笔為你收集整理的【Python】Flask框架系列(三):session和cookie操作、get/post请求、钩子函数的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【Python】部分基础+Flask/J
- 下一篇: 【Python】校选课 第四周作业 py