当然,Flask可以用于开发更复杂的动态Web应用程序。以下是另外几个示例:
示例1:用户登录与会话管理
from flask import Flask, render_template, request, redirect, url_for, session
app = Flask(__name__)
app.secret_key = 'your-secret-key' # 设置密钥用于加密session数据
@app.route('/login', methods=['GET', 'POST'])
def login():
if request.method == 'POST':
username = request.form['username']
password = request.form['password'] # 在实际项目中要进行密码验证
# 假设验证通过
if username == 'admin' and password == 'password':
session['logged_in'] = True
session['username'] = username
return redirect(url_for('dashboard'))
else:
error = '无效的用户名或密码'
else:
error = None
return render_template('login.html', error=error)
@app.route('/dashboard')
def dashboard():
if 'logged_in' in session and session['logged_in']:
return render_template('dashboard.html', username=session['username'])
else:
return redirect(url_for('login'))
@app.route('/logout')
def logout():
session.pop('logged_in', None)
session.pop('username', None)
return redirect(url_for('login'))
if __name__ == '__main__':
app.run(debug=True)
示例2:从数据库获取动态内容
from flask import Flask, render_template
from flask_sqlalchemy import SQLAlchemy
app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///example.db'
db = SQLAlchemy(app)
class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
username = db.Column(db.String(80), unique=True, nullable=False)
email = db.Column(db.String(120), unique=True, nullable=False)
@app.route('/')
def index():
users = User.query.all()
return render_template('index.html', users=users)
# 初始化数据库,在首次运行时执行
if not User.query.all():
db.create_all()
user1 = User(username='user1', email='user1@example.com')
user2 = User(username='user2', email='user2@example.com')
db.session.add(user1)
db.session.add(user2)
db.session.commit()
if __name__ == '__main__':
db.init_app(app)
app.run(debug=True)
在这个示例中,我们使用了Flask-SQLAlchemy扩展来连接SQLite数据库,并查询所有用户数据展示在主页上。你需要在templates目录下创建一个index.html
模板来循环遍历并显示用户列表。
每个示例都展示了Flask的不同应用场景,包括处理表单提交、会话管理以及从数据库中获取并展示动态数据。
当前文章价值6.76元,扫一扫支付后添加微信提供帮助!(如不能解决您的问题,可以申请退款)
评论已关闭!