Boa noite
Quando tento inserir um usuario que já está na base ocorre o erro "AttributeError: 'UsuarioDao' object has no attribute 'busca_por_id"
from flask import Flask, render_template, request, redirect, session, flash, url_for
from models import Jogo, Usuario
from dao import JogoDao, UsuarioDao
import mysql.connector
app = Flask(__name__)
app.secret_key = 'alura'
db = mysql.connector.connect(user='root',password='mysql',host='0.0.0.0',port=3306, database='jogoteca')
jogo_dao = JogoDao(db)
usuario_dao = UsuarioDao(db)
@app.route('/')
def index():
lista = jogo_dao.listar()
return render_template('lista.html', titulo='Jogos', jogos=lista)
@app.route('/novo')
def novo():
if 'usuario_logado' not in session or session['usuario_logado'] == None:
return redirect(url_for('login', proxima=url_for('novo')))
return render_template('novo.html', titulo='Novo Jogo')
@app.route('/criar', methods=['POST',])
def criar():
nome = request. form['nome']
categoria = request. form['categoria']
console = request. form['console']
jogo = Jogo(nome, categoria, console)
jogo_dao.salvar(jogo)
return redirect(url_for('index'))
@app.route('/login')
def login():
proxima = request.args.get('proxima')
return render_template('login.html', proxima=proxima)
@app.route('/autenticar', methods=['POST', ])
def autenticar():
usuario = usuario_dao.busca_por_id(request.form['usuario'])
if usuario:
if usuario.senha == request.form['senha']:
session['usuario_logado'] = usuario.id
flash(usuario.nome + ' logou com sucesso!')
proxima_pagina = request.form['proxima']
return redirect(proxima_pagina)
else:
flash('Não logado, tente novamente!')
return redirect(url_for('login'))
@app.route('/logout')
def logout():
session['usuario_logado'] = None
flash('Nenhum usuário logado!')
return redirect(url_for('index'))
app.run(debug=True)
Código Dao.py
from models import Jogo, Usuario
SQL_DELETA_JOGO = 'delete from jogo where id = %s'
SQL_JOGO_POR_ID = 'SELECT id, nome, categoria, console from jogo where id = %s'
SQL_USUARIO_POR_ID = 'SELECT id, nome, senha from usuario where id = %s'
SQL_ATUALIZA_JOGO = 'UPDATE jogo SET nome=%s, categoria=%s, console=%s where id = %s'
SQL_BUSCA_JOGOS = 'SELECT id, nome, categoria, console from jogo'
SQL_CRIA_JOGO = 'INSERT into jogo (nome, categoria, console) values (%s, %s, %s)'
class JogoDao:
def __init__(self, db):
self.__db = db
def salvar(self, jogo):
cursor = self.__db.cursor()
if (jogo.id):
cursor.execute(SQL_ATUALIZA_JOGO, (jogo.nome, jogo.categoria, jogo.console, jogo.id))
else:
cursor.execute(SQL_CRIA_JOGO, (jogo.nome, jogo.categoria, jogo.console))
jogo.id = cursor.lastrowid
self.__db.commit()
return jogo
def listar(self):
cursor = self.__db.cursor()
cursor.execute(SQL_BUSCA_JOGOS)
jogos = cursor.fetchall()
return jogos
def busca_por_id(self, id):
cursor = self.__db.connection.cursor()
cursor.execute(SQL_JOGO_POR_ID, (id,))
tupla = cursor.fetchone()
return Jogo(tupla[1], tupla[2], tupla[3], id=tupla[0])
def deletar(self, id):
self.__db.cursor().execute(SQL_DELETA_JOGO, (id, ))
self.__db.commit()
class UsuarioDao:
def __init__(self, db):
self.__db = db
Outro ponto que a pagina não está retornando os dados inseridos no banco. Fica uma tabela em branco, sendo que os dados foram inseridos no banco de dados
Obrigado !