Я пытаюсь создать простое приложение Flask, которое будет запускать веб-приложение, которое подключается к базе данных Postgres.

Однако, когда я запускаю код и нажимаю кнопку отправки, метод POST не работает, поэтому он возвращает {{url_for ('success]}}, как указано. Я пробовал добавлять и удалять несколько компонентов. У меня есть методы = ['GET', 'POST'] уже.

App.py :

from flask import Flask, render_template, request
from flask_sqlalchemy import SQLAlchemy

from sqlalchemy.sql import func

app=Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI']='postgresql://postgres:postgres@localhost/Jeopardy'
db=SQLAlchemy(app)

class Data(db.Model):
    __tablename__="allc"
    number = db.Column(db.Integer, primary_key=True)
    category = db.Column(db.String())
    question = db.Column(db.String())
    answer = db.Column(db.String())


    def __init__(self,number,category,question,answer):
        self.number = number
        self.category = category
        self.question = question
        self.answer = answer
        

@app.route("/")
def index():
    return render_template("index.html")

@app.route("/success", methods=['POST','GET'])
def success():
    if request.method=='POST':
        category=request.form['category']
        question=request.form['question']
        answer=request.form['answer']
        number=request.form['number']
    
        print(email, height)
        if db.session.query(Data).filter(Data.number == number).count()== 0:
            data=Data(number,category,question,answer)
            db.session.add(data)
            db.session.commit()
            
            return render_template("success.html")
    
if __name__ == '__main__':
    app.debug=True
    app.run()

Index.html:

<html lang="en">
<title>Jeopardy</title>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device=width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <link href="../static/style.css" rel="stylesheet"  >
</head>
<body>
    <div class="="container">
        <img src="../static/logo.png" alt="Jeopardy" class ="logo">
        <!-- @todo - message-->
        <form action = "s{{url_for('success')}}" methods="POST">
            <div class =  " form-group">
            <h3>Jeopardy Question</h3>
            <input
                    type = "number"
                    name = "Index"
                    placeholder= "Type number" />
                <input
                    type = "text"
                    name = "Question"
                    placeholder= "Type the Jeopardy question here" />
                    <input
                        type = "text"
                        name = "Answer"
                        placeholder= "Type the Jeopardy Answer here"/>
                <button type = "submit"> Submit</button>
        </form>
    </div>
</body>
</html>

При запуске кода мое приложение успешно отображается, но при отправке числа сервер не регистрирует ввод. При загрузке страницы успеха по отдельности она загружается. В терминале вижу: "POST /success HTTP/1.1" 404 -

0
Nishi K 21 Авг 2020 в 09:24

2 ответа

Лучший ответ

У вас опечатка в вашем HTML

Это должно быть method="post", а не methods="post"

РЕДАКТИРОВАТЬ:

Еще одна опечатка в

action = "s{{url_for('success')}}"

Удалите "s"

1
Roger 21 Авг 2020 в 06:36

Вот опечатка:

<form action = "s{{url_for('success')}}" methods="POST">

Измените его на:

<form action = "{{url_for('success')}}" method="POST">
1
Tasnuva 21 Авг 2020 в 06:32