【问题标题】:CS50 Finance "Buy" Function not returning correct errorCS50 财务“购买”功能未返回正确错误
【发布时间】:2020-04-23 00:55:52
【问题描述】:

我正在尝试实现烧瓶代码的购买功能,作为测试,我正在尝试让购买功能中的两个错误代码起作用。但是,无论我在表单中输入什么内容,我总是会返回到错误页面,指出“必须提供用户名”,而且我不确定它是如何到达这一点的,而不是我的两个错误条件之一。

这是我目前的购买功能:

@app.route("/buy", methods=["GET", "POST"])
@login_required
def buy():
    """Buy shares of stock"""
    # requested_quote = stock
    if request.method == "POST":
        if not request.form.get("symbol"):
            return apology("must provide symbol", 403)
        if not request.form.get("amount") or request.form.get("amount") < 1:
            return apology("Please enter amount 1 or greater", 403)

        stock = request.form.get("symbol")
        amount = request.form.get("amount")
        requested_quote = lookup(request.form.get("quote"))
        cash = db.execute("SELECT cash FROM users WHERE id = :id", session["user_id"])

        if requested_quote == None:
            return apology ("Invalid Symbol", 400)
        if (requested_quote["price"] * amount) > cash:
            return apology("Not enough funds", 400)
        else:
             db.execute("INSERT INTO purchases (id, symbol, amount, share_price) VALUES(?, ?, ?, ?)",
             (session["user_id"], stock, amount, requested_quote["price"]))
    else:
        return render_template("buy.html")

这里是登录功能,包含在作业的分发代码中,我认为可能与我的问题有关

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

还有这个:

def login_required(f):
    """
    Decorate routes to require login.

    http://flask.pocoo.org/docs/1.0/patterns/viewdecorators/
    """
    @wraps(f)
    def decorated_function(*args, **kwargs):
        if session.get("user_id") is None:
            return redirect("/login")
        return f(*args, **kwargs)
    return decorated_function

任何帮助将不胜感激!

【问题讨论】:

  • "必须提供用户名" -- 它到底返回到哪里?错误的名称听起来像@login_required 正在调用它。如果是这样@login_required 在上面的任何代码之前执行 - 不需要调试上面写的内容。
  • buy.htmlform 元素的action 属性是什么?
  • @kate-melnykova 好的,所以当我收到那个错误时,它会在我的其余代码之前返回?谢谢,这确实给了我一个开始的地方。不幸的是,我对此感到困惑,因为在该作业的分发代码中给出了另一个“登录”功能,所以我不确定为什么会有问题。我会将代码的其他部分发布到我的原始帖子中。谢谢。
  • @DinoCoderSaurus 我不敢相信我错过了它,但表单操作是返回登录页面。我不敢相信我错过了那个细节,我只是认为这是我的烧瓶代码中的错误。非常感谢您的帮助,这就是答案!有没有办法可以将您的评论标记为答案?对不起,但我还是新手。谢谢。
  • 很高兴你把它整理好了。我添加了一个答案。

标签: flask cs50


【解决方案1】:

您可以在执行flask run 的终端中查看烧瓶日志。这可能表明根本没有调用购买路线。检查 buy.html 中表单元素的 action 属性。也许 login.html 被复制到 buy.html 作为起点,并且该属性从未改变。

【讨论】:

    猜你喜欢
    • 2018-08-04
    • 2022-09-28
    • 2023-04-06
    • 1970-01-01
    • 1970-01-01
    • 2022-10-02
    • 1970-01-01
    • 1970-01-01
    • 2022-06-14
    相关资源
    最近更新 更多