運行環境:html
python2.7前端
flask 0.11html5
flask-wtf 0.14.2python
wtform可以經過一個類定義一些字段,這些字段會在前端生成標籤,而且經過設置字段的驗證規則,自動判斷前端輸入數據的格式。正則表達式
通常用於用戶登陸,用戶註冊等信息錄入。flask
1 from wtforms import Form 2 from flask import Flask,render_template,request,redirect 3 from wtforms.fields import core 4 from wtforms.fields import html5 5 from wtforms.fields import simple 6 from wtforms import validators 7 from wtforms import widgets 8 import sys 9 reload(sys) 10 sys.setdefaultencoding('utf8') 11 #python2.7 轉碼用的,避免顯示中文爲亂碼 12 13 14 app = Flask(__name__,template_folder='templates') 15 app.debug=True 16 17 class LoginForm(Form): 18 name = simple.StringField( 19 label='用戶名', #前端顯示中文 20 validators=[ 21 validators.DataRequired(message='用戶名不能爲空'), 22 validators.Length(min=6,max=18,message='用戶名長度必須大於%(min)d且小於%(max)d') 23 ], #字段的驗證規則 24 widget=widgets.TextInput(), #頁面上顯示的標籤 25 render_kw={'class':'form=control'} #給上面插件生成的時候添加屬性,好比bootstrap的屬性 26 ) 27 pwd = simple.PasswordField( 28 label='密碼', 29 validators=[ 30 validators.DataRequired(message='密碼不能爲空'), 31 validators.Length(min=8,message='用戶名長度必須大於%(min)d'), 32 validators.Regexp(regex="^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[$@$!%*?&])[A-Za-z\d$@$!%*/&]{8,}", 33 message='密碼至少8個字符,至少1個大寫字母,1個小寫字母'), 34 35 ], 36 widget=widgets.PasswordInput(), 37 render_kw={'class':'from-control'} 38 ) 39 #字段,內部包含正則表達式 40 41 @app.route('/login',methods=['GET','POST']) 42 def login(): 43 if request.method == 'GET': 44 form = LoginForm() 45 return render_template('login.html',form=form) 46 #將form對象傳給前端 47 else: 48 form = LoginForm(formdata=request.form) #從請求體from中取值 49 if form.validate(): #驗證 50 print "用戶提交數據經過,提交的值爲:",form.data 51 else: 52 print form.errors #錯誤信息 53 return render_template('login.html',form=form) 54 55 56 57 @app.route('/') 58 def hello_world(): 59 return 'Hello World!' 60 61 62 if __name__ == '__main__': 63 app.run()
1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <meta http-equiv="x-ua-compatible" content="IE=edge"> 6 <meta name="viewport" content="width=device-width, initial-scale=1"> 7 <title>Title</title> 8 </head> 9 <body> 10 <h1>登錄</h1> 11 <form method="post"> 12 <p>{{ form.name.label }} {{ form.name }} {{ form.name.errors[0] }}</p> 13 <p>{{ form.pwd.label }} {{ form.pwd }} {{ form.pwd.errors[0] }}</p> 14 <input type="submit" value="提交"> 15 </form> 16 </body> 17 </html>
在前端,直接經過Form對象來取字段中的值,以及該值中的錯誤信息,錯誤信息咱們通常取第一個便可,已經可以告訴用戶信息錯誤了。bootstrap