在Flask中为IntegerField表单不允许的方法

时间:2018-04-14 14:21:29

标签: python flask

我试图在Flask中的表单上设置整数字段验证,但我不断获得' Method Not Allowed'。我无法看清我的路线有什么问题?

我的主要文件是:

from flask import Flask, render_template
from flask_wtf import FlaskForm
from wtforms import IntegerField

# from perfect_numbers import classify

app = Flask(__name__)
app.config['SECRET_KEY'] = 'MySecretKey'

# num = 12
# Classify = classify(num)

class PerfectForm(FlaskForm):
    number = IntegerField(4)

@app.route('/', methods=['POST'])
def form():
    form = PerfectForm()
    return render_template('index.html', form = form)

if __name__ == '__main__':
    app.run(debug=True)

然后我有一个标准的layout.html文件:

<!DOCTYPE html>
<html lang="en" dir="ltr">
  <head>
    <meta charset="utf-8">
    <title>PERFECT App</title>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/css/bootstrap.min.css" integrity="sha384-rwoIResjU2yc3z8GV/NPeZWAv56rSmLldC3R/AZzGRnGxQQKnKkoFVhFQhNUwEyJ" crossorigin="anonymous">
    <script src="https://code.jquery.com/jquery-3.1.1.slim.min.js" integrity="sha384-A7FZj7v+d/sdmMqp/nOQwliLvUsJfDHW+k9Omg/a/EheAdgtzNs3hpfag6Ed950n" crossorigin="anonymous"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.4.0/js/tether.min.js" integrity="sha384-DztdAPBWPRXSA/3eYEEUWrWCy7G5KFbe8fFjk5JAIxUYHKkDx6Qin1DkWx51bBrb" crossorigin="anonymous"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/js/bootstrap.min.js" integrity="sha384-vBWWzlZJ8ea9aCX4pEW3rVHjgjt7zpkNpZk+02D9phzyeVkE+jo0ieGizqPLForn" crossorigin="anonymous"></script>
  </head>
  <body>
    {% block body %}{% endblock %}
  </body>
</html>

我的index.html是:

{% extends 'layout.html' %}

{% block body %}
  <h1>PERFECT NUMBERS</h1>
  <p>This is a basic Flask App to illustrate Aliquot Sums and Perfect Numbers</p>

  <p>Input a number to check if it is abundant, perfect, or deficient</p>
  <form action="{{ url_for('/') }}" method="POST">
    {{ form.csrf_token }}
    {{ form.number }}
  </form>
  <!-- {{ num }} is {{ classify }} -->
{% endblock %}

1 个答案:

答案 0 :(得分:1)

首先,将app.route()签名更改为

@app.route('/', methods=['POST', 'GET'])

您必须填写表单并提交给您的应用以接收POST请求。当您首次在浏览器上加载页面时,您在技术上向烧瓶发送GET请求,然后返回页面。

要单独处理您的POST请求,请执行以下操作:

@app.route('/', methods=['POST', 'GET'])
def form():
    if request.method == 'POST':
        # Do something with request (access form elements with request.get(key))
        return 'Somehing here'
    form = PerfectForm()
    return render_template('index.html', form = form)