Пользователь Flask Web App связывается с проблемой списка sqlite3 - PullRequest
0 голосов
/ 19 июня 2019

Я кодирую веб-приложение для издевательства над отчетами на python с флягой и базу данных в sqlite3 с 3 списками usuarios, victimas и testigos.В таблице usuarios перечислены все зарегистрированные пользователи (школы), а в таблице victimas показаны все отчеты, сделанные учащимися, в которых участвует СПЕЦИАЛЬНАЯ ШКОЛА.Например: Показать все отчеты из школы "Гонза".Поэтому, когда школа входит в систему, она может видеть все сделанные отчеты, но проблема в том, что я не могу связать название школы со списком жертв.

Я думаю, что проблема в session[user_id] в строке 162.и затем в строке 232, когда я пытаюсь hechos = db.execute("SELECT * FROM victimas WHERE escuela = :escuela", escuela=session["user_id"]), это вызывает ошибку.У меня были два разных сообщения об ошибках отладчика, которые указаны ниже:

KeyError: 'user_id' в строке 232 hechos = db.execute ("SELECT * FROM victimas WHERE escuela =: escuela", escuela= session ["user_id"])

Иногда эта ошибка также появляется

NameError: имя 'escuela' не определено в строке 241, в tablatestigos return render_template ("tablatestigos.html ", escuela = escuela)

@app.route("/regescuela", methods=["GET", "POST"])
def register():
    session.clear()

    if request.method == "POST":
        if not request.form.get("username"):
            return apology("No ha introducido un nombre de usuario!")
        elif not request.form.get("password"):
            return apology("No ha introducido una contraseña!")
        elif request.form.get("password") != request.form.get("confirmation"):
            return apology("Las contraseñas no coinciden.")
    else:
        usumayu = request.form.get("username")
        return render_template("regescuela.html")
    result = db.execute("INSERT INTO usuarios (username, hash) VALUES(:username, :hash)", username= request.form.get("username").upper(), hash=generate_password_hash(request.form.get("password")))

    if not result:
        return apology("Este usuario ya existe! Prueba con otro!")
    session["user_id"] = result[0]["username"]
    flash("Registrado!")
    return redirect("/")





@app.route("/login", methods=["GET", "POST"])
def login():
    """Log user in"""

    # Forget any user_id
    session.clear()

    # User reached route via POST (as by submitting a form via POST)
    if request.method == "POST":

        # Ensure username was submitted
        if not request.form.get("username"):
            return apology("Debe ingresar un nombre de usuario.", 403)

        # Ensure password was submitted
        elif not request.form.get("password"):
            return apology("Debe ingresar una contraseña.", 403)

        # Query database for username
        rows = db.execute("SELECT * FROM usuarios WHERE username = :username",
                          username=request.form.get("username"))

        # Ensure username exists and password is correct
        if len(rows) != 1 or not check_password_hash(rows[0]["hash"], request.form.get("password")):
            return apology("Usuario o contraseña incorrectos", 403)

        # Remember which user has logged in
        session["user_id"] = rows[0]["username"]

        # Redirect user to home page
        return redirect("/")

    # User reached route via GET (as by clicking a link or via redirect)
    else:
        return render_template("login.html")

@app.route("/logout")
def logout():
    """Log user out"""

    # Forget any user_id
    session.clear()

    # Redirect user to login form
    return redirect("/")

@app.route("/victima", methods=["GET", "POST"])
def victima():
    if request.method == "POST":
        if not (request.form.get("nombreescuela" and "curso" and "box")):
            return apology("Debes completar todo el formulario.")
        if  not (len(request.form.get("curso")) == 2):
            return apology("Ingrese corectamente el curso (no mas de 2 digitos). El primero debe ser un numero y el segundo la letra de su division. Ejemplo: 5A  | (si su colegio no tiene division ingrese el numero acompañado de una x. Ejemplo: 5x) | ")
        if not ((request.form.get("curso")[0] == "1" or "2" or "3" or "4" or "5" or "6" or "7" or "8" or "9") and (request.form.get("curso")[1].isalpha())):
            return apology("Ingrese el curso correctamente. No se aceptan mas de 2 digitos. El primero debe ser un numero y el segundo la letra de su division. Ejemplo: 5A  | (si su colegio no tiene division ingrese el numero acompañado de una x. Ejemplo: 5x) | ")

        db.execute("INSERT INTO victimas (escuela, curso, hecho) VALUES(:escuela, :curso, :hecho)", escuela=request.form.get(
            "nombreescuela"), curso=request.form.get("curso").upper(), hecho=request.form.get("box"))

        flash("Formulario enviado con éxito!")

        return redirect("/")
    else:
        return render_template("victima.html")

@app.route("/testigo", methods=["GET", "POST"])
def testigo():
    if request.method == "POST":
        if not (request.form.get("nombreescuela" and "curso" and "victima" and "box")):
            return apology("Debes completar todo el formulario.")
        if  not (len(request.form.get("curso")) == 2):
            return apology("Ingrese corectamente el curso. No mas de 2 digitos. El primero debe ser un numero y el segundo la letra de su division. Ejemplo: 5A  | (si su colegio no tiene division ingrese el numero acompañado de una x. Ejemplo: 5x) | ")
        if not ((request.form.get("curso")[0] == "1" or "2" or "3" or "4" or "5" or "6" or "7" or "8" or "9") and (request.form.get("curso")[1].isalpha())):
            return apology("Ingrese el curso correctamente. No se aceptan mas de 2 digitos. El primero debe ser un numero y el segundo la letra de su division. Ejemplo: 5A |  (si su colegio no tiene division ingrese el numero acompañado de una x. Ejemplo: 5x) | ")

        db.execute("INSERT INTO testigos (escuela, curso, victima, hecho) VALUES(:escuela, :curso, :victima, :hecho)", escuela=request.form.get(
            "nombreescuela"), curso=request.form.get("curso").upper(), victima=request.form.get("victima"), hecho=request.form.get("box"))

        flash("Formulario enviado con éxito!")

        return redirect("/")
    else:
        return render_template("testigo.html")



@app.route("/reportesrecibidos", methods=["GET", "POST"])
@login_required
def reportesrecibidos():
    return render_template("reportesrecibidos.html")

@app.route("/tablavictimas")
@login_required
def tablavictimas():
    hechos = db.execute("SELECT * FROM victimas WHERE escuela = :escuela", escuela=session["user_id"])
    return render_template("tablavictimas.html", escuela=escuela)

@app.route("/tablatestigos")
@login_required
def tablatestigos():
    hechos = db.execute("SELECT * FROM testigos WHERE escuela = :escuela", escuela=session["user_id"])
    return render_template("tablatestigos.html", escuela=escuela)

Сообщения об ошибках:

KeyError: 'user_id' в строке 232 hechos = db.execute (" SELECT *ОТ ПОБЕДЫ WHERE escuela =: escuela ", escuela = session [" user_id "])

Иногда эта ошибка также появляется

NameError: имя 'escuela' не определенов строке 241 в tablatestigos возвращаем render_template ("tablatestigos.html", escuela = escuela)

1 Ответ

0 голосов
/ 19 июня 2019

У вас есть эта ошибка:

NameError: имя 'escuela' не определено в строке 241, в tablatestigos return render_template ("tablatestigos.html", escuela = escuela)

потому что escuela не определена. Я думаю, что сообщение об ошибке очень ясно. В любом случае, чтобы решить эту проблему, вам нужно определить escuela следующим образом:

@app.route("/tablatestigos")
@login_required
def tablatestigos():
    escuela = session["user_id"]
    hechos = db.execute("SELECT * FROM testigos WHERE escuela = :escuela",
    escuela=escuela)
    return render_template("tablatestigos.html", escuela=escuela)

Вторая ошибка:

KeyError: 'user_id' в строке 232 hechos = db.execute ("SELECT * FROM victimas WHERE escuela =: escuela ", escuela = session [" user_id "])

поднято, потому что сессия ["user_id"] не существует. Для этого есть много причин: во-первых, возможно, пользователь не вошел в систему. Возможно, у вас возникла проблема в декораторе @login_required. Во-вторых, возможно, вы не определили secret_key для своего приложения. В этом случае вы потеряете содержимое сеанса после каждого обновления страницы. Чтобы решить эту проблему, вам нужно определить secret_key для вашего приложения в основном файле:

app = Flask('application')
app.secret_key = "some secret key"

Обратите внимание, что есть более безопасное решение для определения secret_key для вашего приложения, но это самое простое решение.

...