Python之Flask登录认证--装饰器

from flask import Flask, render_template, request, Response, redirect, session, url_for

app = Flask(__name__)
# app.debug = True  # 自动重启功能
app.config.from_object("settings.DevelopmentConfig")
USRS = {
    1: {"name": "张三", "age": 18, 'gender': '男'},
    2: {"name": "张三", "age": 18, 'gender': '男'},
    3: {"name": "张三", "age": 18, 'gender': '男'},
    4: {"name": "张三", "age": 18, 'gender': '男'}
}

"""
redirect_to="/", 重定向到另一个页面
subdomain="admin"  子域名

请求相关的全部在request

"""
import functools


def wapper(func):
    @functools.wraps(func)  # 设置函数的元信息
    def inner(*args, **kwargs):
        user = session.get('user_info')
        # if not user
        if user is None:
            return redirect("/login")
        return func(*args, **kwargs)

    return inner


@app.route('/detail/<int:nid>', methods=['GET', 'POST'], redirect_to="/", subdomain="admin")  # 重定向
@wapper
def detail(nid):
    print(nid)
    info = USRS.get(nid)
    return render_template('detail.html', info=info)
    pass


@app.route('/index', methods=['GET', 'POST'])
@wapper
def index():
    user = session.get('user_info')
    if user is None:
        url = url_for('l1')  # 反向生成
        return redirect(url)
    return render_template('index.html', user_dict=USRS)


@app.route('/login', methods=['GET', 'POST'], endpoint=l1)
def login():
    if request.method == "GET":
        return render_template('login.html')
    else:
        # request.query_string
        usename = request.form.get('username')
        password = request.form.get("password")
        if usename == 'alex' and password == "123":
            # 记录用户登录
            session['user_info'] = usename
            return redirect('/index')
        return render_template('login.html  ', error="用户名或者密码错误")


if __name__ == '__main__':
    app.run()
# 装饰器(检验用户认证)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flask-Login是一个Flask扩展,它提供了用户会话管理,包括登录、注销、记住会话等功能。在Flask应用程序中使用Flask-Login可以很容易地实现用户认证和授权。 关于Flask-Login的登录页面,一般来说,你需要创建一个登录表单,然后在视图函数中处理表单提交的数据。具体步骤如下: 1. 创建登录表单,可以使用Flask-WTF扩展来实现表单验证和CSRF保护。 2. 在视图函数中处理表单提交的数据,如果表单验证通过,则使用Flask-Login提供的login_user函数将用户登录状态保存到会话中。 3. 在模板中显示登录表单,并提供注销按钮。 下面是一个简单的示例代码: ```python from flask import Flask, render_template, redirect, url_for, request from flask_login import LoginManager, login_user, logout_user, login_required, UserMixin app = Flask(__name__) app.config['SECRET_KEY'] = 'your_secret_key_here' login_manager = LoginManager() login_manager.init_app(app) class User(UserMixin): def __init__(self, id): self.id = id @login_manager.user_loader def load_user(user_id): return User(user_id) @app.route('/login', methods=['GET', 'POST']) def login(): if request.method == 'POST': user_id = request.form['user_id'] password = request.form['password'] if user_id == 'admin' and password == 'password': user = User(user_id) login_user(user) return redirect(url_for('index')) else: return render_template('login.html', error='Invalid username or password') else: return render_template('login.html') @app.route('/logout') @login_required def logout(): logout_user() return redirect(url_for('index')) @app.route('/') @login_required def index(): return render_template('index.html') if __name__ == '__main__': app.run(debug=True) ``` 在这个示例中,我们创建了一个User类来表示用户,实现了一个load_user函数来根据用户ID加载用户对象。在登录视图函数中,我们处理表单提交的数据,如果验证通过,则使用login_user函数将用户登录状态保存到会话中。在注销视图函数中,我们使用logout_user函数将用户登录状态从会话中删除。在主页视图函数中,我们使用@login_required装饰器来保护需要登录才能访问的页面。 关于Flask-Login的更多信息,你可以参考官方文档:https://flask-login.readthedocs.io/en/latest/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值