簡體   English   中英

燒瓶 wtform 驗證失敗

[英]flask wtform validation fails

class FlowerForm(FlaskForm):
    cr_score = IntegerField('Credit Score', validators=[DataRequired()])
    geo = StringField('Geography', validators=[DataRequired()])
    gen = StringField('Gender', validators=[DataRequired()])
    age = IntegerField('Age', validators=[DataRequired()])
    ten = IntegerField('Tenure', validators=[DataRequired()])
    bal = IntegerField('Balance', validators=[DataRequired()])
    num = IntegerField('Number Of Products', validators=[DataRequired()])
    has_card = IntegerField('Has Credit Card', validators=[DataRequired()])
    is_active = IntegerField('Is Active Member', validators=[DataRequired()])
    sal = IntegerField('Estimated Salary', validators=[DataRequired()])
    
    submit = SubmitField('Analyze')

@app.route('/', methods=['GET', 'POST'])
def index():
    # Create instance of the form.
    form = FlowerForm(request.form)
    # If the form is valid on submission
    if request.method == "POST" and form.validate_on_submit():
   
        # Grab the data from the input on the form.
        session["cr_score"] = form.cr_score.data
        session["geo"] = form.geo.data
        session["gen"] = form.gen.data
        session["age"] = form.age.data
        session["ten"] = form.ten.data
        session["bal"] = form.bal.data
        session["num"] = form.num.data
        session["has_card"] = form.has_card.data
        session["is_active"] = form.is_active.data
        session["sal"] = form.sal.data
        
        return redirect(url_for("prediction"))
    print(form.errors)
    return render_template('home.html', form=form)

@app.route('/prediction')
def prediction():
    #Defining content dictionary
    content = {}
    
    content["CreditScore"] = int(session["cr_score"])
    content["Geography"] = str(session["geo"])
    content["Gender"] = str(session["gen"])
    content["Age"] = int(session["age"])
    content["Tenure"] = int(session["ten"])
    content["Balance"] = int(session["bal"])
    content["NumOfProducts"] = int(session["num"])
    content["HasCrCard"] = int(session["has_card"])
    content["IsActiveMember"] = int(session["is_active"])
    content["EstimatedSalary"] = int(session["sal"])


    results = return_prediction(model = model, scaler = scaler, onehot = ohencoder, lab_enc=labencoder, sample_json = content)
    return render_template('prediction.html',results=results)

表單驗證在這里似乎不起作用。 我也試過form.valid_on_submit

我的 home.html 文件和 prediction.html 文件都包含form.hidden_tag()

if 語句以某種方式被覆蓋,我最終回到主頁

HTML home.html代碼:

<h1>Welcome to Customer Retention Prediction</h1>
<h2>Please enter customer details below:</h2>
<form action = "/" method=”POST”>
 {# This hidden_tag is a CSRF security feature. #}
 {{form.hidden_tag()}}
 {{ form.csrf_token }}
 {{form.cr_score.label}} {{form.cr_score}}
 <br>
 {{form.geo.label}} {{form.geo}}
 <br>
 {{form.gen.label}} {{form.gen}}
 <br>
 {{form.age.label}} {{form.age}}
 <br>
 {{form.ten.label}} {{form.ten}}
 <br>
 {{form.bal.label}} {{form.bal}}
 <br>
 {{form.num.label}} {{form.num}}
 <br>
 {{form.has_card.label}}{{form.has_card}}
 <br>
 {{form.is_active.label}} {{form.is_active}}
 <br>
 {{form.sal.label}} {{form.sal}}
 <br>
 {{form.submit()}}
</form>

prediction.html代碼:

<h1>Thank You.</h1>
 {# This hidden_tag is a CSRF security feature. #}
 {{form.hidden_tag()}}
<h2>Probability of this customer leaving the bank is: {{results}}</h2>

您是否嘗試過在 if 語句 try print(form.errors)之后打印錯誤,它應該給您錯誤no crsf token

在 html 中添加這個你使用form.hidden_tag()在它下面使用{{ form.csrf_token }}

[...]
if request.method == "POST" and form.validate():
        # Grab the data from the input on the form.
        session["cr_score"] = form.cr_score.data
        session["geo"] = form.geo.data
        session["gen"] = form.gen.data
        session["age"] = form.age.data
        [....]
print(form.errors)
return render_template('home.html', form=form)

編輯:您沒有在表單標簽中使用操作。

在html文件中:應該是這個

<form action="/" method="POST">

您的索引功能將是:

@app.route('/', methods=['GET', 'POST'])
def index():
    # Create instance of the form.
    form = FlowerForm(request.form)
    # If the form is valid on submission
    if request.method == "POST":
        print("yoyo")
        if form.validate_on_submit():
            
            # Grab the data from the input on the form.
            session["cr_score"] = form.cr_score.data
            session["geo"] = form.geo.data
            session["gen"] = form.gen.data
            session["age"] = form.age.data
            session["ten"] = form.ten.data
            session["bal"] = form.bal.data
            session["num"] = form.num.data
            session["has_card"] = form.has_card.data
            session["is_active"] = form.is_active.data
            session["sal"] = form.sal.data
            
            return redirect(url_for("prediction"))
    print(form.errors)
    return render_template('home.html', form=form)

您的 home.html 將是:

<h1>Welcome to Customer Retention Prediction</h1>
<h2>Please enter customer details below:</h2>
<form action="/" method="POST">
 {# This hidden_tag is a CSRF security feature. #}
 {{form.hidden_tag()}}

 {{ form.csrf_token }}
 {{form.cr_score.label}} {{form.cr_score}}
 <br>
 {{form.geo.label}} {{form.geo}}
 <br>
 {{form.gen.label}} {{form.gen}}
 <br>
 {{form.age.label}} {{form.age}}
 <br>
 {{form.ten.label}} {{form.ten}}
 <br>
 {{form.bal.label}} {{form.bal}}
 <br>
 {{form.num.label}} {{form.num}}
 <br>
 {{form.has_card.label}}{{form.has_card}}
 <br>
 {{form.is_active.label}} {{form.is_active}}
 <br>
 {{form.sal.label}} {{form.sal}}
 <br>
 {{form.submit()}}
  {{form.errors}}
</form>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM