这是我在Flask中创建的基本登录表单,但在注册页面上出现此错误。
mysql_exceptions.OperationalError
_mysql_exceptions.OperationalError: (1046, 'No database selected')
我收到错误,找不到数据库。错误是什么?它没有连接到数据库。我使用MySQL for Python 3.6:
from flask import Flask, render_template, flash, redirect, url_for, session,
logging, request
from data import Articles
from flask_mysqldb import MySQL
from wtforms import Form, StringField, TextAreaField, PasswordField,
validators
from passlib.hash import sha256_crypt
app = Flask(__name__)
# db = MySQLdb.connect('localhost','root','','myflaskapp')
#Config Mysql
app.config['MySQL_HOST'] = 'localhost'
app.config['MySQL_USER'] = 'root'
app.config['MySQL_PASSWORD'] = ''
app.config['MySQL_DB'] = 'myflaskapp'
app.config['MySQL_CURSORCLASS'] = 'DictCursor'
mysql = MySQL(app)
Articles = Articles()
@app.route('/')
def index():
return render_template('home.html')
@app.route('/link')
def link():
return render_template("link.html")
@app.route('/articles')
def articles():
return render_template('articles.html', articles = Articles)
@app.route('/articles/<string:id>/')
def article(id):
return render_template('article.html' , id=id)
class RegisterForm(Form):
name = StringField('Name',[validators.Length(min=2,max = 50)])
username = StringField('Username',[validators.Length(min = 4, max=25)])
email = StringField('Email', [validators.Length(min=6, max=50)])
password = PasswordField('Password',[
validators.DataRequired(),
validators.EqualTo('confirm',message="Passwords do not match")
])
confirm = PasswordField('Confirm Password')
@app.route('/register', methods =['GET','POST'])
def register():
form = RegisterForm(request.form)
if request.method == 'POST'and form.validate():
name = form.name.data
email = form.email.data
username = form.username.data
password = sha256_crypt.encrypt(str(form.password.data))
cur = mysql.connection.cursor()
cur.execute("INSERT INTO users(name,username,email,password)
VALUES(%s,%s,%s,%s)",(name,username,email,password))
mysql.connection.commit()
cur.close()
flash("You are nor registered and login", "success")
redirect(url_for('index'))
return render_template('register.html', form = form)
return render_template('register.html', form = form)
if __name__ == "__main__":
app.secret_key = 'secret123'
app.run(debug = True)
答案 0 :(得分:0)
在代码顶部添加以下配置参数。请注意,values
必须包含db用户名和密码。 userpass
是XAMPP目录中mysql套接字文件的位置。
socket