首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >用户登录到Flask吗?

用户登录到Flask吗?
EN

Stack Overflow用户
提问于 2019-12-30 12:40:10
回答 1查看 165关注 0票数 1

我一直在学习Flask超级教程(https://blog.miguelgrinberg.com/post/the-flask-mega-tutorial-part-iv-database)的第三章和第四章。我正在尝试在我托管在pythonanywhere上的flask网页上设置用户登录。我可以成功注册一个帐户(我可以看到添加到我的数据库中的记录),但是,当我尝试登录时,Flask在搜索用户名时找不到该记录,并返回None。我不确定为什么会发生这种事。有点复杂的是,我使用的是MySQL数据库,而不是本教程使用的SQLLite数据库。

config.py:

代码语言:javascript
运行
复制
import os
basedir = os.path.abspath(os.path.dirname(__file__))

class Config(object):
    SECRET_KEY = os.environ.get('SECRET_KEY') or 'something'
    SQLALCHEMY_DATABASE_URI = 'mysql+mysqlconnector://username:password@jplank.mysql.pythonanywhere-services.com/jplank$default'
    SQLALCHEMY_TRACK_MODIFICATIONS = False

flask_app.py:

代码语言:javascript
运行
复制
from config import Config
from flask_sqlalchemy import SQLAlchemy
from werkzeug.urls import url_parse
from flask import Flask, render_template, flash, redirect, url_for, request
from pandas import DateOffset, DataFrame, date_range, to_datetime
from flask_login import current_user, login_user, logout_user, login_required, LoginManager
import MySQLdb
from flask_bootstrap import Bootstrap
from numpy import nan
from dateutil.relativedelta import relativedelta
import datetime
import math
from yearfrac import CalcYearFrac
import decimal
from sqlalchemy import create_engine

app = Flask(__name__)
app.config.from_object(Config)
db = SQLAlchemy(app)
login = LoginManager(app)
login.login_view = 'login'
Bootstrap(app)

from forms import NameForm, LoginForm, RegistrationForm
import routes, models

@app.route('/table', methods=('GET', 'POST'))
@login_required
def calculatetable():
[...]

models.py:

代码语言:javascript
运行
复制
from flask_app import db, login
from werkzeug.security import generate_password_hash, check_password_hash
from flask_login import UserMixin

class User(UserMixin, db.Model):
    __tablename__ = "user"

    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(64), index=True, unique=True)
    email = db.Column(db.String(120), index=True, unique=True)
    password_hash = db.Column(db.String(128))

    def __repr__(self):
        return '<User {}>'.format(self.username)

    def set_password(self, password):
        self.password_hash = generate_password_hash(password)

    def check_password(self, password):
        return check_password_hash(self.password_hash, password)

@login.user_loader
def load_user(id):
    return User.query.get(int(id))

routes.py:

代码语言:javascript
运行
复制
from flask import render_template, flash, redirect, url_for, request
from flask_login import login_user, logout_user, current_user
from werkzeug.urls import url_parse
from flask_app import app, db
from forms import LoginForm, RegistrationForm
from models import User
from config import Config

@app.route('/logout')
def logout():
    logout_user()
    return redirect(url_for('index'))

@app.route('/login', methods=['GET', 'POST'])
def login():
    if current_user.is_authenticated:
        return redirect(url_for('index'))
    form = LoginForm()
    if form.validate_on_submit():
        user = 
User.query.filter_by(username=form.username.data).first()
        if user is None:
            flash('user is none')
            flash(form.username.data)
            return redirect(url_for('login'))
        elif not user.check_password(form.password.data):
            flash('not hash match')
            return redirect(url_for('login'))
        login_user(user, remember=form.remember_me.data)
        next_page = request.args.get('next')
        if not next_page or url_parse(next_page).netloc != '':
            next_page = url_for('calculatetable')
        return redirect(next_page)
    return render_template('login.html', title='Sign In', form=form)

@app.route('/register', methods=['GET', 'POST'])
def register():
    if current_user.is_authenticated:
        return redirect(url_for('index'))
    form = RegistrationForm()
    if form.validate_on_submit():
        user = User(username=form.username.data, email=form.email.data)
        user.set_password(form.password.data)
        db.session.add(user)
        db.session.commit()
        flash('Congratulations, you are now a registered user!')
        return redirect(url_for('login'))
    return render_template('register.html', title='Register', form=form)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-12-31 04:53:36

我设法解决了这个问题。我设置MySQL表的方式有一个问题,我没有将某些列标识为索引。重新创建表解决了问题。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59525788

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档