【发布时间】:2020-08-01 05:40:06
【问题描述】:
菜鸟问题。我正在构建登录/注册页面,在注册页面上,我正在使用 flask_wtf 来验证某些内容,例如密码长度、电子邮件格式以及用户提供的两个密码是否匹配。这是我用来执行此操作的 flask_wtf 代码。
# import statements omitted for brevity
class RegistrationForm(FlaskForm):
username = StringField('Username',
validators=[DataRequired(), Length(min=2, max=20)])
email = StringField('Email',validators=[DataRequired(), Email()])
password = PasswordField('Password', validators=[DataRequired()])
confirm_password = PasswordField('Confirm Password',
validators=[DataRequired(),Length(min=4, max=20), EqualTo('password')])
submit = SubmitField('Sign Up')
检查输入后,我正在使用 sqlalchemy 检查用户名和电子邮件是否已存在于我的数据库中。我现在面临的问题是我无法让 flask_wtf 验证表单。我可以输入我想要的任何内容,它将被转换为 sql 查询。这是我处理注册和用户输入验证的两条烧瓶路由。
@app.route('/register',methods=['GET','POST'])
def register():
form = RegistrationForm()
if form.validate_on_submit():
return redirect(url_for('check_user_input'))
return render_template('register.html',form=form)
@app.route('/status',methods=['POST'])
def check_user_input():
name = request.form.get("username")
email = request.form.get("email")
password = request.form.get("password")
if db.execute("SELECT * FROM DB WHERE username= :username",{"username":name}).rowcount==1:
return render_template("404.html", message="Sorry username already exists")
elif db.execute("SELECT * FROM DB WHERE email= :email",
{"email":email}).rowcount==1:
return render_template("404.html", message="Sorry email already exists")
else:
db.execute("INSERT INTO DB (username,email,password) VALUES
(:username,:email,:password)",
{"username":name, "email":email,"password":password})
db.commit()
return render_template("success.html")
如何让 flask_wtf 表单先进行验证,然后将输入交给check_user_input() 函数?
我的 register.html 包含以下行。
<form class="form-signin" method="POST" action="{{url_for('check_user_input')}}">
任何帮助将不胜感激。
【问题讨论】:
标签: python-3.x flask sqlalchemy flask-wtforms