Python库Flask可以用于开发更复杂的动态Web应用程序

2024-04-15 22:52 Python库Flask可以用于开发更复杂的动态Web应用程序已关闭评论

当然,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元,扫一扫支付后添加微信提供帮助!(如不能解决您的问题,可以申请退款)

你可能感兴趣的文章

来源:每日教程每日一例,深入学习实用技术教程,关注公众号TeachCourse
转载请注明出处: https://www.teachcourse.cn/3350.html ,谢谢支持!

资源分享

分类:python 标签:, ,
Eclipse关联android-support-v4包的两种方法 Eclipse关联android-support-v4
Android项目结构与分析源码,其中的秘密,你知道吗? Android项目结构与分析源码,其
Python依赖库国内常用镜像源及用法 Python依赖库国内常用镜像源及用
线上产品接入bugly热更新 线上产品接入bugly热更新

评论已关闭!