-1

我正在使用 Python/Flask/mysql.connector 设置登录表单,但是如果结果 > 0: TypeError :在“NoneType”和“int”的实例之间不支持“>”。

我尝试了不同的方法,例如将 if 语句更改为不同的内容并验证字典是否正确,但我得到了同样的错误。

#Login
@app.route('/login', methods=['GET', 'POST'])
def login():
    if request.method == 'POST':
        #Get Form
        username = request.form['username']
        password_candidate = request.form['password']

        #Get user by username
        result = cursor.execute("SELECT * FROM users WHERE username = %s", [username])

        if result > 0:
            #Get stored hash
            data = cursor.fetchone()
            password = data['password']

            #compare the Passwords
            if sha256_crypt.verify(password_candidate, password):
                #Passed
                session['logged_in'] = True
                session['username'] = username

                flash('You are now logged in', 'success')
                return redirect(url_for('dashboard'))
            else:
                error = 'Invalid Login'
                return render_template('login.html', error=error)
            #Close connection
            cursor.close()
        else:
            error = 'Username not found'
            return render_template('login.html', error=error)
    return render_template('login.html')

如果您用于注册的信息有效,我希望该表格可以让您登录,或者如果信息无效,则显示登录失败。显然,这些信息将从 mysql 数据库中提取。

4

2 回答 2

0
result = cursor.execute("SELECT * FROM users WHERE username = %s", [username])

这条线导致了问题。它返回一个空值可能是因为用户名不存在。

我看到你有一个if...else来处理这个,但如果结果的值是None,你不能将它与一个整数值进行比较——0在这种情况下。

在 python 中,您可以通过执行以下操作来检查值是否不是None

if result:
    # code
else:
    # code

希望这可以帮助。祝你好运。

于 2019-10-18T23:04:10.990 回答
0

我解决了这个问题。import mysql.connector我从from flask_mysqldb import MySQL

删除 mysql.connector 配置并按照以下示例添加数据库详细信息

 app.config['MYSQL_HOST'] = 'localhost'
 app.config['MYSQL_USER'] = 'scott'
 app.config['MYSQL_PASSWORD'] = ''
 app.config['MYSQL_DB'] = 'users'
 app.config['MYSQL_CURSORCLASS'] = 'DictCursor'

之后我必须初始化应用程序

mysql = MySQL(app)

最后一部分是创建一个光标,如下例所示。

cursor = mysql.connection.cursor()

我还更改了我的 if 语句以反映 @Harshal Parekh 的建议。

代替

    if result > 0:

我用了

    if result:

希望这对其他人有帮助。

于 2019-10-19T13:06:23.123 回答