91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Flask如何處理Web表單

發布時間:2021-02-01 09:22:18 來源:億速云 閱讀:161 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關Flask如何處理Web表單的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

web表單是web應用程序的基本功能。

它是HTML頁面中負責數據采集的部件。表單有三個部分組成:表單標簽、表單域、表單按鈕。表單允許用戶輸入數據,負責HTML頁面數據采集,通過表單將用戶輸入的數據提交給服務器

在Flask中,為了處理web表單,我們一般使用Flask-WTF擴展,它封裝了WTForms,并且它有驗證表單數據的功能。

WTForms支持的HTML標準字段

字段對象說明
字段對象說明
StringField文本字段
TextAreaField多行文本字段
PasswordField密碼文本字段
HiddenField隱藏文件字段
DateField文本字段,值為 datetime.date 文本格式
DateTimeField文本字段,值為 datetime.datetime 文本格式
IntegerField文本字段,值為整數
DecimalField文本字段,值為decimal.Decimal
FloatField文本字段,值為浮點數
BooleanField復選框,值為 True 和 False
RadioField一組復選框
SelectField下拉列表
SelectMutipleField下拉列表可選擇多個值
FileField文件上傳字段
SubmitField表單提交按鈕
FormField把表單作為字段嵌入另一個表單
FieldList一組指定類型的字段

WTForms常用驗證函數

驗證函數說明
DateRequired確保字段中有數據
EqualTo比較兩個字段的值,常用于比較兩次密碼的輸入
Length驗證輸入的字符串長度
NumberRange驗證輸入的值在數字范圍內
URL驗證URL
AnyOf驗證輸入值在可選列表中
NoneOf驗證輸入值不在可選列表中

使用 Flask-WTF 需要配置參數 SECRET_KEY

CSRF_ENABLED是為了CSRF(跨站請求偽造)保護。 SECRET_KEY用來生成加密令牌,當CSRF激活的時候,該設置會根據設置的密匙生成加密令牌。在HTML頁面中直接寫form表單:

<form method='post'>
  <input type="text" name="username" placeholder='Username'>
  <input type="password" name="password" placeholder='password'>
  <input type="submit">
</form>

視圖函數中獲取表單數據:

from flask import Flask,render_template,request

@app.route('/login',methods=['GET','POST'])
def login():
  if request.method == 'POST':
    username = request.form['username']
    password = request.form['password']
    print username,password
  return render_template('login.html',method=request.method)123456789

使用 Flask-WTF 實現表單

配置參數

app.config['SECRET_KEY'] = 'SECRET_KEY'1

模板頁面

<form method="post">
 #設置csrf_token
 {{ form.csrf_token() }}
 {{ form.us.label }}
 <p>{{ form.us }}</p>
 {{ form.ps.label }}
 <p>{{ form.ps }}</p>
 {{ form.ps2.label }}
 <p>{{ form.ps2 }}</p>
 <p>{{ form.submit() }}</p>
 {% for x in get_flashed_messages() %}
   {{ x }}
 {% endfor %}
</form>1234567891011121314
視圖函數
#coding=utf-8
from flask import Flask,render_template,\
  redirect,url_for,session,request,flash

#導入wtf擴展的表單類
from flask_wtf import FlaskForm
#導入自定義表單需要的字段
from wtforms import SubmitField,StringField,PasswordField
#導入wtf擴展提供的表單驗證器
from wtforms.validators import DataRequired,EqualTo
app = Flask(__name__)
app.config['SECRET_KEY']='1'

#自定義表單類,文本字段、密碼字段、提交按鈕
class Login(FlaskForm):
  us = StringField(label=u'用戶名',validators=[DataRequired()])
  ps = PasswordField(label=u'密碼',validators=[DataRequired(),EqualTo('ps2','err')])
  ps2 = PasswordField(label=u'確認密碼',validators=[DataRequired()])
  submit = SubmitField(u'提交')

@app.route('/login')
def login():
  return render_template('login.html')

#定義根路由視圖函數,生成表單對象,獲取表單數據,進行表單數據驗證
@app.route('/',methods=['GET','POST'])
def index():
  form = Login()
  if form.validate_on_submit():
    name = form.us.data
    pswd = form.ps.data
    pswd2 = form.ps2.data
    print name,pswd,pswd2
    return redirect(url_for('login'))
  else:
    if request.method=='POST':
      flash(u'信息有誤,請重新輸入!')
    print form.validate_on_submit()

  return render_template('index.html',form=form)
if __name__ == '__main__':
  app.run(debug=True)

感謝各位的閱讀!關于“Flask如何處理Web表單”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

贵州省| 侯马市| 安康市| 乐亭县| 鹤山市| 吐鲁番市| 垫江县| 自贡市| 清原| 潞西市| 东安县| 永丰县| 东明县| 辽源市| 轮台县| 襄樊市| 沁源县| 石阡县| 进贤县| 巴塘县| 通榆县| 沧州市| 福安市| 宝兴县| 保亭| 当涂县| 双峰县| 钦州市| 昌宁县| 东宁县| 翁牛特旗| 汝南县| 垫江县| 贡觉县| 灵山县| 清丰县| 赣榆县| 铁岭县| 武清区| 新和县| 韶关市|