Ошибка атрибута Flask Python: объект ‘_AppCtxGlobals’ не имеет атрибута ‘_connection’

#python #flask #cs50

#python #flask #cs50

Вопрос:

Я создаю фреймворк Flask и использую CS50 модуль SQLite для взаимодействия с моей базой данных SQLite, в которой хранятся пользователи, их имена пользователей и пароли. Я также пытался использовать sqlite3 модуль, но я был более знаком с этим, и это давало мне так много ошибок.

Когда я flask run загружаю веб-страницу, но когда я пытаюсь войти в систему или даже зарегистрироваться, это выдает мне следующую ошибку:

 AttributeError: '_AppCtxGlobals' object has no attribute '_connection'
 

Вот мой код для функции register:

 @app.route("/register", methods=["GET", "POST"])
def register():
    """Register user"""

    if request.method == "POST":

        # Making sure the user actually typed in something in the fields
        username = request.form.get("username")
        password = request.form.get("password")
        password_confirm = request.form.get("password_confirm")

        # Ensure user provided username
        if not username:
            return apology("Must provide username", 400)

        # Ensure user provided password
        elif not password:
            return apology("Must provide password", 400)

        # Confirming passwords match
        elif not request.form.get("password") == request.form.get("password_confirm"):
            return apology("Passwords do not match", 400)

        # Hash the password and insert the new user into database
        hashed_password = generate_password_hash(password)
        new_user_id = db.execute("INSERT INTO users (username, hash) VALUES (:username, :hashed_password)", username=username, hashed_password=hashed_password)

        # Is the username unique?
        if not new_user_id:
            return apology("Username taken", 400)

        # Remember which user has logged in
        session["user_id"] = new_user_id
 

И если это поможет, моя функция входа в систему:

 @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("must provide username", 403)

        # Ensure password was submitted
        elif not request.form.get("password"):
            return apology("must provide password", 403)

        # Query database for username
        rows = db.execute("SELECT * FROM users 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("invalid username and/or password", 403)

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

        # 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")
 

Комментарии:

1. Возможно, это проблема с конфигурацией базы данных, дважды проверьте конфигурацию вашей базы данных.

2. @Md.NahidurRahman у вас есть какие-либо идеи, как это сделать или что я должен искать?

3. Если вы переключились с cs50 на sqlite3 обратно на библиотеки cs50, уверены ли вы в настройках кода дистрибутива в приложении. py не повреждены?

4. Привет! Я решил это, перейдя из режима производства в режим разработки.