繁体   English   中英

Python Flask登录login_required重定向

[英]Python Flask Login login_required redirecting

我正在开发Flask应用程序,并使用Flask-Login进行身份验证。 一切都已设置并运行。 但是,当用户登录并尝试访问需要登录的页面时,他们将被重定向到登录页面。

当观看控制台时,我得到200的GET登录页面,获得200的POST登录信息,从登录​​页面到主页的302,然后从主页的另一个302返回登录。

请参见下面的代码。

from flask import (Flask, render_template, g, flash, redirect, url_for,
                    request)
from flask_bcrypt import check_password_hash
from flask_login import (LoginManager, UserMixin, login_required, login_user,
                        logout_user, current_user)

import models
import forms

application = Flask(__name__)
application.secret_key = "xxx-xxx-xxx-xxx"
login_manager = LoginManager()
login_manager.init_app(application)
login_manager.login_view = "login"

@application.before_request
def before_request():
    g.db = models.DATABASE
    g.db.connect()
    g.user = current_user

@application.after_request
def after_request(response):
    g.db.close()
    return response

@login_manager.user_loader
def load_user(email):
    try:
        return models.User.select().where(
                                models.User.email == email).get()
    except models.DoesNotExist:
        return None

@application.route("/register", methods=['GET', 'POST'])
def register():
    form = forms.RegisterForm()
    if form.validate_on_submit():
        flash("Yay! You registered!", "success")
        models.User.create_user(
            email = form.email.data,
            password = form.password.data
        )
        return redirect(url_for('home'))
    return render_template('register.html',form=form)

@application.route("/login", methods=['GET', 'POST'])
def login():
    form = forms.LoginForm()
    if form.validate_on_submit():
        next = request.args.get('next')
        try:
            user = models.User.get(models.User.email == form.email.data)
        except models.DoesNotExist:
            flash("Your email or password doesn't match!", "error")
        else:
            if check_password_hash(user.password, form.password.data):
                login_user(user, remember=True)
                flash("Welcome back!", "success")
                return redirect(next or url_for("home"))
            else:
                flash("Your email or password doesn't match!", "error")
    return render_template("login.html", form=form)

@application.route("/logout")
@login_required
def logout():
    logout_user()
    flash("You've been logged out!", "success")
    return redirect(url_for("home"))

@application.route("/")
@login_required
def home():
    return render_template("home.html")

if __name__ == "__main__":
    models.initialize()
    application.run(host='0.0.0.0')

这是模型:

import datetime

from flask_login import UserMixin
from flask_bcrypt import generate_password_hash, check_password_hash
from peewee import *

DATABASE = MySQLDatabase("fakedatabasename", host="fakehostname", user="fakeusername", password="fakepassword")


class BaseModel(Model):
    class Meta:
        database = DATABASE


class Preachers(BaseModel):
    preacher_id = PrimaryKeyField()
    preacher_first_name = CharField(max_length=27)
    preacher_last_name = CharField(max_length=27)
    preacher_email = CharField()


class Sermons(BaseModel):
    sermon_id = PrimaryKeyField()
    sermon_title = CharField(max_length=27)
    sermon_description = CharField(max_length=140)
    sermon_date = DateTimeField(default=datetime.datetime.now())
    sermon_preacher_id = IntegerField()
    sermon_video_uri = CharField(max_length=255)


class User(UserMixin,BaseModel):
    user_id = PrimaryKeyField()
    email = CharField(index=True, unique=True)
    password = CharField()
    date_created = DateTimeField(default=datetime.datetime.now())

    @classmethod
    def create_user(cls, email, password):
        try:
            cls.create(
                email = email,
                password = generate_password_hash(password)
            )
        except IntegrityError:
            raise ValueError("User already exists")


def initialize():
    DATABASE.connect()
    DATABASE.create_tables([Preachers, Sermons, User], safe=True)
    DATABASE.close()

因此,事实证明,在使用Peewee和Flask-Login时,您需要让Peewee为User模型提供其默认主键,而不是使用自定义键。 删除user_id = PrimaryKeyField() ,删除表,然后重新启动修复它。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM