错误:在Flask中找不到数据库

时间:2018-04-19 12:23:38

标签: python flask

这是我在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)

1 个答案:

答案 0 :(得分:0)

在代码顶部添加以下配置参数。请注意,values必须包含db用户名和密码。 userpass是XAMPP目录中mysql套接字文件的位置。

socket