成功烧瓶登录返回路线:/ NONE

时间:2017-12-13 02:37:46

标签: python flask login

这个烧瓶应用程序正确地提示输入用户名和密码 - 但是根据日志文件,尽管有这个问题,仍然返回route / NONE,会话似乎是有效的,并且可以访问其他@login_required路由。任何有关正在发生的事情的想法都将受到赞赏。

登录模板:login.html

{% extends "bootstrap/base.html" %}
{% block content %}
<div class="container">
<div class="row">
    <form class="form-signin" action="/logmein" method="POST">
        <h2 class="form-signin-heading"> PCBevo Login</h2>
        <div class="col-2">
            <label for="username" class="sr-only">Username</label>
            <input type="text" id="username" class="form-control" placeholder="username" name="username" required autofocus>
        </div>
        <div class="col-3">
            <label for="inputPassword" class="sr-only">Password</label>
            <input type="password" id="inputPassword" class="form-control" placeholder="password" name="password" required>
        </div>
        <div class="col-4">
            <button class="btn btn-lg btn-primary btn-block" type="submit" value="Submit">Sign in</button>
        </div>
    </form>
</div>

</div> <!-- /container -->
{% endblock %}

以下是SQLAlchemy用户模型:

class User(UserMixin, db.Model):
    __tablename__ = "users"
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(254), unique=True)
    email = db.Column(db.String(50), unique=True)
    password = db.Column(db.String(80))
    groups = db.Column(db.String(80))

    def __init__(self, username, email, password, groups):
        self.username = username
        self.email = email
        self.password = password
        self.groups = groups if isinstance(groups, str) else      ','.join(groups)

    def __repr__(self):
        clsname = self.__class__.__name__
        return "{}({}) ".format(clsname, self.username)

    def is_developer(self):

        return isinstance(self.groups, str) and 'dev' in self.groups.split(',')

login_manager和问题路径的应用设置的所选属性:

login_manager = LoginManager()
login_manager.init_app(app)
login_manager.login_view = 'login'

@login_manager.user_loader
def load_user(user_id):
    return User.query.get(int(user_id))

@app.route('/login')
def login():
    session['next'] = request.args.get('next')
    return render_template('login.html')

@app.route('/logmein', methods=['POST'])
def logmein():
    username = request.form['username']
    password = request.form['password']
    user = User.query.filter_by(username=username).first()

    if not user:
        return '<h1>User not found!</h1>'

    stored_password = user.password
    if check_password_hash(stored_password, password):
       login_user(user)
        try:
            return redirect(session['next'])
        except KeyError:
            return '<h1>You are now logged in!</h1>'
    else:
       return '<h1>Wrong password!</h1>'

1 个答案:

答案 0 :(得分:2)

session['next']之前检查return redirect(session['next'])

如果您运行/login而不是/login?next=some_url

,则可以为空

因为request.args.get('next')将返回默认值None

但你可以使用自己的默认值即。主页"/"

request.args.get('next', "/" )
相关问题