Flask 實現登陸 + session


Flask 實現登陸 + session

案例一:

# -*- coding: utf-8 -*-
# @Time    : 2019/9/24 16:26
# @Author  : AnWen
from flask import Flask, render_template, request, redirect, session

app = Flask(__name__)
app.secret_key = '!@#$%^&*()11'
app.debug = True


@app.route('/login', methods=['GET', 'POST'])
def login():
	if request.method == 'GET':
		return render_template('login.html')
	if request.method == 'POST':
		if request.form.get('username') == 'anwen':
			session['user'] = request.form.get('username')
			return redirect('/')
# 交由客戶端保管機制
# 開啟session['ursernsm'] = request.form.get('username')
# {"username":anwen}
# 序列化字典 == 字符串
# 加密字符串 Secret key 密鑰字符串
#
# 接受反序列化Session;從cookie中獲取到一個session key的值
# 通過Secretkey 解密session
# 反序列化成字典

@app.route('/')
def index():
	print(session.get('user'))
	return render_template('index.html')


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

案例二:

# 1 、要求:
# 	1.登錄頁面
# 	2.學生概況頁面 ID name 點擊詳情
# 	3.學生詳情頁面 ID name age gender

# 2.使用session驗證登錄狀態
# 思考:如何記錄登錄次數

# 3.基於Session編寫登錄驗證裝飾器
# 思考:如何給兩個以上的視圖函數增加裝飾器
from flask import Flask, request, redirect, render_template, session
from functools import wraps

USER = {'username': 'anwen', 'password': "123"}
STUDENT_DICT = {
	1: {'name': 'Old', 'age': 38, 'gender': '中'},
	2: {'name': 'Boy', 'age': 73, 'gender': '男'},
	3: {'name': 'EDU', 'age': 84, 'gender': '女'},
}
app = Flask(__name__)
app.secret_key = "!@#$%^&*()"
app.debug = True

# 裝飾器裝飾多個視圖函數
def wrapper(func):
	@wraps(func)  # 保存原來函數的所有屬性,包括文件名
	def inner(*args, **kwargs):
		# 校驗session
		if session.get("user"):
			ret = func(*args, **kwargs)  # func = home
			return ret
		else:
			return redirect("/login")
	return inner


# 首頁
@app.route('/')
@wrapper
def index():
	# if session.get('user'):
	return render_template('index.html')
	# else:
	# 	return redirect("/login")


# 登錄
@app.route('/login', methods=["GET", "POST"])
def login():
	if request.method == 'GET':
		return render_template('login.html')
	if request.method == 'POST':
		if request.form.get("username") == USER["username"] and request.form.get("password") == USER["password"]:
			session["user"] = request.form.get("username")
			return redirect("/")
		else:
			return redirect("/login")


# 學生概況頁面
@app.route('/desc')
@wrapper
def desc():
	# if session.get("user"):
	return render_template('desc.html', stu_dic=STUDENT_DICT)
	# else:
	# 	return redirect("/login")


# 學生詳情頁面
@app.route('/info')
@wrapper
def info():
	# if session.get("user"):
	return render_template('info.html', stu_dic=STUDENT_DICT)
	# else:
	# 	return redirect("/login")


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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM