-1

我正在尝试运行 Flask 应用程序,显示能够提交用户评论的图书概览页面。但是我遇到了两个问题:

1) 当我尝试运行下面的代码时,“/books/553803700”的 url 将我重定向回主页。

我想有一个问题

review = db.execute("SELECT review FROM reviews WHERE review_by = :review_by", {"review_by": current_user}).fetchone()

2)如果我在上面评论那个字符串,页面可以工作。但是当我尝试提交评论时,它显示“未找到。在服务器上未找到请求的 URL。如果您手动输入了 URL,请检查您的拼写并重试。”

应用程序.py 文件:


from flask import Flask, session, render_template, request, redirect, flash, jsonify
from flask_session import Session
from sqlalchemy import create_engine
from sqlalchemy.orm import scoped_session, sessionmaker

....
### some app configuration, other routes
...

@app.route("/books/<isbn>")
def book(isbn):
    try:
        if globals()["session"]["username"]:
            current_user = globals()["session"]["username"]
            book = db.execute("SELECT * FROM books WHERE isbn = :isbn", {"isbn": isbn}).fetchone()

            ### here is that string
            review = db.execute("SELECT review FROM reviews WHERE review_by = :review_by",
                                {"review_by": current_user}).fetchone()

            if review is True:
                return render_template("book.html", book=book, review=review)

            else:
                return render_template("book.html", book=book)


    except:
        return redirect("/login")


@app.route("/books/<isbn>/review", methods=['POST'])
def review(isbn):
    review = request.form.get("review")
    current_user = globals()["session"]["username"]
    db.execute("INSERT INTO reviews (isbn, review_by, review) VALUES (:isbn, :review_by, :review)",
               {"isbn": isbn, "review_by": current_user, "review": review})
    db.commit()
    db.close()
    return redirect("/book/" + isbn)

book.html 文件:

{% extends "layout.html" %}

{% block getin %}

    <h1>{{ book.title }}</h1>
    <ul>
        <li>Title: {{ book.title }}</li>
        <li>ISBN: {{ book.isbn }}</li>
        <li>Author: {{ book.author }}</li>
        <li>Year: {{ book.year }}</li>
    </ul>
{% endblock %}

{% block user_info %}
    <h2>Would you like to leave your review?</h2>

    {% if review %}
    <div class="user-review">
    {{ review }}

    </div>

    {% else %}
        <form name="submit-review" action="/book/{{book.isbn}}/review" method="POST">
        <textarea type="text" name="review" class="form-control" placeholder="Leave your review here">
        </textarea>

        <button class="btn btn-primary">Submit</button>
    </form>

    {% endif %}

    <div class="row" style="margin-top:50px">
        GoodReads reviews:
    </div>
{% endblock %}

非常感谢您帮助解决这两个问题

4

2 回答 2

0

解决第二个错误:

未找到。在服务器上找不到请求的 URL。如果您手动输入了 URL,请检查您的拼写并重试。

您需要将反斜杠添加/到 route @app.route("/books/<isbn>)。这将类似于:

@app.route("/books/<isbn>/")
def book(isbn):
   #...
于 2019-06-23T14:13:38.637 回答
0

看看你的行动的价值。

...
    <form name="submit-review" action="/book/{{book.isbn}}/review" method="POST">
...

让我们用这个替换它:

...
    <form name="submit-review" action="{{ url_for('book', isbn=book.isbn) }}" method="POST">
...

否则尝试简单地删除它。

...
    <form name="submit-review" action="" method="POST">
...
于 2020-01-24T11:26:45.793 回答