2016-11-28 15 views
0

Всякий раз, когда я пытаюсь представить мою форму я получить следующее сообщение об ошибке:Колба - csrf_token отсутствует ошибку

{'department': [u'Not a valid choice'], 'email': [u'This field is required.'], 'csrf_token': ['CSRF token missing'], 'name': [u'This field is required.'], 'address': [u'This field is required.']} 

Сейчас им просто пытаюсь исправить сообщение csrf_token отсутствующей ошибки. Но я есть CSRF токен тег в моем шаблоне поэтому я не понимая, почему это происходит ...

<form enctype="multipart/form-data" action="/index" method="post" role="form"> <!-- how the data is obtained from the form (POST method) --> 
    {{ form.csrf_token }} 
    <div class="form-group"> 
     <label style="margin-top: 10px;" for="name">Name:</label> 
     {{ form.name(class_="form-control") }} <!-- this creates the name form field --> 
     <br> 
     <label for="address">Address:</label> 
     {{ form.address(class_="form-control", rows='5', cols='40') }} <!-- this creates the adress form field --> 
     <br> 
     <label for="email">E-mail Address:</label> 
     {{ form.email(class_="form-control") }} 
     <br> 
     <label for="telephone">Phone Number: </label> 
     {{ form.telephone(class_="form-control") }} 
     <br> 
     <label for="file_upload">Upload CV: </label> 
     {{ form.file_upload(class_="form-control") }} 
     <br> 
     <label for="Department">Department:</label> 
     {{ form.department(class_="form-control")}} 
     <br> 
     </select> 
    </div> 
<button name="submit" type="submit" class="btn btn-primary">Submit</button> </form> <!-- submit button --> 

Я также думаю, что моя конфигурация правильно ...

WTF_CSRF_ENABLED = True 
SECRET_KEY = 'this-is-a-secret-key' 

я упускаю что нибудь? Спасибо за любую помощь!

EDIT: (! Извините за беспорядок, начинающий) В соответствии с просьбой вот мой конфиг

from flask import Flask, render_template, session, flash, request, redirect,  url_for 
from flask_wtf import Form 
from flask_sqlalchemy import SQLAlchemy 
from werkzeug.utils import secure_filename 
from wtforms import TextField, TextAreaField, validators, StringField, SubmitField, BooleanField, RadioField, SelectField, FileField, IntegerField 
from .forms import ApplicationForm, DataRequired 
import os 
import re 
import sqlite3 
from flask_wtf.csrf import CsrfProtect 


SECRET_KEY = 'you-will-never-guess' 


#configuration 
DEBUG = True 
app = Flask('Application') 
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///applicants.sqlite3' 

app.config.from_object(__name__) 
from app import views 

CsrfProtect(app) 
WTF_CSRF_ENABLED = True 

DEBUG = True 

UPLOAD_FOLDER = '/Uploads' 
app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER 
FILE_TYPES = set(['txt', 'doc', 'docx', 'odt', 'pdf', 'rtf', 'text', 'wks', 'wps', 'wpd']) 

def application(): 
    form = ApplicationForm(request.form) 
    return render_template('index.html','home.html', form=form) 

db = SQLAlchemy(app) 
class Applicants(db.Model): 
    id = db.Column('applicant_id', db.Integer, primary_key = True) 
    name = db.Column(db.String(100)) 
    address = db.Column(db.String(200)) 
    telephone = db.Column(db.String(15)) 
    email = db.Column(db.String(100)) 
    department = db.Column(db.String(30)) 
    file_upload = db.Column(db.Boolean) 

def __init__(self, name, address, telephone, email, department, file_upload): 
    self.name = name 
    self.address = address 
    self.telephone = telephone 
    self.email = email 
    self.department = department 
    self.file_upload = file_upload 

db.create_all() 

if __name__ == "Application": 
    app.run() 
+0

Попробуйте 'form.hidden_tag' над form.csrf? http://stackoverflow.com/a/21501593 – Erik

+0

Можете ли вы показать свой конфигурационный объект? и как вы передаете его в свое приложение? – ettanany

+0

@ Erik пробовал это, не делал ничего другого, поскольку hidden_tag и csrf_token делают ту же/подобную вещь, на которую я верю. –

ответ

0

Я думаю, что вам нужно, чтобы очистить ваши настройки немного, попробуйте заменить все ниже Вашего импорта и выше def application(): соответствии с этим:

app = Flask(__name__) 
CsrfProtect(app) 
app.config.update(
    DEBUG = True, 
    WTF_CSRF_ENABLED = True, 
    SECRET_KEY = 'you-will-never-guess', 
    UPLOAD_FOLDER = '/Uploads', 
    SQLALCHEMY_DATABASE_URI = 'sqlite:///applicants.sqlite3', 
    FILE_TYPES = ['txt', 'doc', 'docx', 'odt', 'pdf', 'rtf', 'text', 'wks', 'wps', 'wpd'] 
) 
from app import views 

DEBUG и SECRET_KEY настройки выглядят как они, возможно, не были правильно установлены, поэтому ошибка CSRF подходило.

+0

Я включил это исправление, однако проблема все еще возникает. Тем не менее, я получаю только токен, если ошибка была заполнена и отправлена. если форма оставлена ​​пустой и отправлена, то ошибка не возникает. Не знаю, почему это происходит, но большое спасибо за помощь в очистке моего кода! –