操作系统:MacOS
MySQL版本:8.0.16
连接MySQL的代码:
app.config['MYSQL_HOST']='localhost'
app.config['MYSQL_USERNAME']='root'
app.config['MYSQL_PASSWORD']='123456'
app.config['MYSQL_DB']='Teaching_Sys'
app.config['MYSQL_CURSORCLASS']='DictCursor'
密码正确,里面没有任何特殊字符,并且我已经选择了“使用旧密码加密”来初始化数据库(有人使用这个技巧解决了这个问题)
我已经设置了一个名为Teaching_Sys的表
使用flask将新数据插入表的代码:
username=form_reg.username.data
email=form_reg.username.data
password = sha256_crypt.hash(form_reg.password.data)
#create cursor
cur=mysql.connection.cursor()
cur.execute("INSERT INTO users(username,email,password) VALUES(%s,%s,%s)",(username,email,password))
#commit to db
mysql.connection.commit()
cur.close()
完整的错误消息是:
MySQLdb._exceptions.OperationalError: (1045, "Access denied for user 'yiling'@'localhost' (using password: YES)")
发生在队列中
cur=mysql.connection.cursor()
而yiling是我的系统账户名。
我还检查了root@localhost的用户权限
最佳答案
OperationalError: (1045, "Access denied for user 'rajendra'@'localhost' (using password: NO)")
答案就在这里
app.config['MYSQL_USERNAME']='root'
应该是
app.config['MYSQL_USER']='root'
关于使用flask_mysqldb时Mysql错误1045(用户访问被拒绝),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55892542/