返回顶部
首页 > 资讯 > 后端开发 > Python >python中的Flask Web表单如何使用
  • 186
分享到

python中的Flask Web表单如何使用

2023-06-30 15:06:21 186人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

这篇文章主要介绍“python中的flask WEB表单如何使用”,在日常操作中,相信很多人在Python中的Flask Web表单如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”p

这篇文章主要介绍“python中的flask WEB表单如何使用”,在日常操作中,相信很多人在Python中的Flask Web表单如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”python中的Flask Web表单如何使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

普通表单提交

在创建模板login.html页面中直接写fORM表单。

login.html

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta Http-equiv="X-UA-Compatible" content="IE=edge">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <title>Document</title></head><body>    <form action="" method="post">        <input type="text" name="username" placeholder="Username">        <input type="passWord" name="password" placeholder="Password">        <input type="submit" value="提交">    </form>    {% if method == 'GET' %}        请求方式:{{method}}    {% elif method == 'POST' %}        请求方式:{{method}}        用户名:{{ username }}        密码:{{ password }}    {% endif %}    </body></html>

接下来,在视图函数中获取表单数据

login.py

from flask import Flask, render_template, requestapp = Flask(__name__)# index 视图函数@app.route('/login', methods=['GET', 'POST'])def login():    context = dict()    if request.method == 'POST':        username = request.form['username']        password = request.form['password']        print(username, password)        context = {            'username': username,            'password': password,        }        context.update({'method': request.method})    else:        context.update({'method': request.method})    return render_template('login.html', **context)@app.route('/')def index():    return 'hello'if __name__ == '__main__':    app.run(debug=True)

python中的Flask Web表单如何使用

当我们点击提交之后,则会显示:

python中的Flask Web表单如何使用

上面的实现方式是直接采用表单的提交方式。但是有个弊端,假如参数很多的情况下,后台也需要一一进行验证,每次都是先接收参数,再对参数进行校验的话,工作量就会非常的庞大,而且还会出现csrf攻击,这时我们就可以采用Flask-WTF来创建表单,从而避免上述弊端。

Flask-WTF基础

Flask-WTF的主要作用是对用户的请求数据进行验证。我们可以使用pip命令安装该依赖,

pip install flask-wtf

在flask web程序中,因为类FlaskForm由Flask-WTF拓展定义,所以可以从flask.wtf中导入FlaskForm。而字段和函数可以直接从WTForms包中导入,WTForms包中可以支持如下所示的HTML标准字段。

字段说明
StringField表示文本字段
TextAreaField表示多行文本字段
PasswordField表示密码文本字段
HiddenField表示隐藏文本字段
DateField表示日期的文本字段
DateTimeFiled表示时间的文本字段
IntegerFiled表示整数类型的文本字段
DecimalField表示Decimal类型的文本字段
FloatFiled表示Float类型的文本字段
RadioFiled表示单选框字段
SelectFiled表示下拉列表字段

WTForm也包含验证器,它对表单字段进行验证,非常方便。

字段说明
DataRequire检查输入的字段是否为空
Email检查字段是否符合邮件格式的约定
IPAddress在输入字段中验证IP地址
Length验证输入字段中的字符串长度是否符合给定长度
NumberRange验证给定范围内输入字段中的文字
URL验证是否为合法的URL

使用Flask-WTF处理表单

编写两个视图函数,以及一个form表单类,用于注册以及跳转index页面。

login.py

from flask import Flask, render_template, redirect, url_for, sessionfrom flask_wtf import FlaskFormfrom wtforms import StringField, PasswordField, SubmitFieldfrom wtforms.validators import DataRequired, EqualToapp = Flask(__name__)app.config["SECRET_KEY"] = "xhosd6f982yfhowefy29f"class ReGISterForm(FlaskForm):    username = StringField(label="用户名", validators=[DataRequired('用户名不能为空')])    password = PasswordField(label="密码", validators=[DataRequired('密码不能为空')])    password_comfirm = PasswordField(label="确认密码", validators=[DataRequired('密码不能为空'), EqualTo('password', '两次密码不一致')])    submit = SubmitField(label='提交')@app.route('/register', methods=['GET', 'POST'])def register():    form  = RegisterForm()    if form.validate_on_submit():        uname = form.username.data        pwd = form.password.data        pwd_com = form.password_comfirm.data        print(uname, pwd, pwd_com)        session['username'] = uname        return redirect(url_for('index'))    return render_template('register.html', form=form)@app.route('/index')def index():    username = session.get('username', '')    return 'hello %s' % usernameif __name__ == '__main__':    app.run(debug=True)

接下来编写一个html模板文件,用于用户注册使用。

register.html

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta http-equiv="X-UA-Compatible" content="IE=edge">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <title>Document</title></head><body>    <form action="" method="post">        {{form.csrf_token}}        {{form.username.label}}        <p>{{ form.username }}</p>        {% for msg in form.username.errors %}            <p>{{ msg }}</p>        {% endfor %}        {{form.password.label}}        <p>{{ form.password }}</p>        {% for msg in form.password.errors %}            <p>{{ msg }}</p>        {% endfor %}        {{form.password_comfirm.label}}        <p>{{ form.password_comfirm }}</p>        {% for msg in form.password.errors %}            <p>{{ msg }}</p>        {% endfor %}        {{ form.submit }}    </form></body></html>

Flask消息闪现

在Flask框架中,方法flash()功能是实现消息闪现提示效果。Flask官方对闪现的解释是对用户的请求做出无刷新的响应。类似于ajax的刷新效果。

举一个简单的例子,当用户通过表单发送完请求之后,假如用户名或者是密码输入错误,那么服务器就会返回错误的提示信息,并在表单页面上显示。

具体代码,如下所示:

login.py

from flask import Flask, flash, redirect, render_template, request, url_forapp = Flask(__name__)app.secret_key = 'random string'@app.route('/')def index():    return render_template('index.html')@app.route('/login', methods=['GET', 'POST'])def login():    error = None    if request.method == 'POST':        if request.form['username'] != 'admin' or request.form['password'] != 'admin':            flash("用户名或密码错误")        else:            flash('登录成功')            return redirect(url_for('index'))    return render_template('login.html')if __name__ == '__main__':    app.run(debug=True)

login.html

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta http-equiv="X-UA-Compatible" content="IE=edge">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <title>登录</title></head><body>    <form action="" method="post">        <p>username</p>        <input type="text" name="username">        <p>password</p>        <input type="password" name="password">        <input type="submit" value="登录">    </form>    {% for message in get_flashed_messages() %}        {% if message %}            {{message}}        {% endif %}    {% endfor %}</body></html>

index.html

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta http-equiv="X-UA-Compatible" content="IE=edge">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <title>Document</title></head><body>    {% with messages = get_flashed_messages() %}        {% if messages %}            {% for message in messages %}                <p>{{ message }}</p>            {% endfor %}        {% endif %}    {% endwith %}    <h4>welcome</h4>    <a href="{{url_for('login')}}" rel="external nofollow" >login</a></body></html>

上面的代码实现了URL的跳转,我们首先会进入首页,首页中包含了进入登录页面的链接。

python中的Flask Web表单如何使用

python中的Flask Web表单如何使用

python中的Flask Web表单如何使用

文件上传

在Flas Web程序中要实现文件的上传非常简单,与传递post和get非常的类似。基本流程如下:

  • (1)将在客户端上传的文件保存到flask.request.files对象。

  • (2)使用flask.request.files对象获取上传上来的文件名和文件对象

  • (3)调用文件对象中的方法save()将文件保存到指定的目录中。

简易的文件上传程序如下所示:

upload.py

from flask import Flask, flash, render_template, requestapp = Flask(__name__)@app.route('/upload', methods=['GET', 'POST'])def upload():    if request.method == 'GET':        return render_template('upload.html')    else:        file = request.files['file']        if file:            file.save(file.name + '.png')            return '上传成功'@app.route('/')def index():    return render_template('index.html')if __name__ == '__main__':    app.run(debug=True)

index.html

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta http-equiv="X-UA-Compatible" content="IE=edge">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <title>Document</title></head><body>    <h2>文件上传首页</h2>    <a href="{{url_for('upload')}}" rel="external nofollow" >文件上传</a></body></html>

upload.html

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta http-equiv="X-UA-Compatible" content="IE=edge">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <title>文件上传</title></head><body>    <form action="" method="post" enctype="multipart/form-data">        <input type="file" name="file">        <input type="submit" value="点击我上传">    </form></body></html>

本程序需要点击跳转之后才能进入文件上传页面,这样写的目的只是因为我比较懒,不想再浏览器中输入一大串的url。

python中的Flask Web表单如何使用

python中的Flask Web表单如何使用

python中的Flask Web表单如何使用

python中的Flask Web表单如何使用

目前上述程序仅仅可以上传图片!

文件上传的另一种写法

在Flask中上传文件的步骤非常简单,首先需要一个HTML表单,将enctype属性设置为"multipart/form-data"即可。URL处理程序会从request.file[]对象中提取文件,并将它保存到所需要的位置上。

每个上传的文件首先会保存到服务器上的临时位置,然后将其保存到最终的实际位置。建议使用secure_filename函数获取。

index.html

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta http-equiv="X-UA-Compatible" content="IE=edge">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <title>Document</title></head><body>    <form action="/uploader" method="post" enctype="multipart/form-data">        <input type="file" name="file">        <input type="submit" value="提交">    </form></body></html>

upload.py

from flask import Flask, render_template, requestfrom werkzeug.utils import secure_filenameimport osapp = Flask(__name__)app.config['UPLOAD_FLODER']= 'upload/' # 设置文件保存的路径@app.route('/')def upload_file():    return render_template('upload.html')@app.route('/uploader', methods=['GET', 'POST'])def uploader():    if request.method == 'POST':        f = request.files['file']        print(request.files)        f.save(os.path.join(app.config['UPLOAD_FLODER'], secure_filename(f.filename)))        return '上传成功'    else:        render_template('upload.html')if __name__ == '__main__':    app.run(debug=True)

到此,关于“python中的Flask Web表单如何使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: python中的Flask Web表单如何使用

本文链接: https://lsjlt.com/news/329841.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • python中的Flask Web表单如何使用
    这篇文章主要介绍“python中的Flask Web表单如何使用”,在日常操作中,相信很多人在python中的Flask Web表单如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”p...
    99+
    2023-06-30
  • Python Flask-web表单使用详解
    Flask-WTF扩展可以把处理web表单的过程变成一种愉悦的体验。 一、跨站请求伪造保护 默认情况下,Flask-WTF能够保护所有表单免受跨站请求伪造的攻击。恶意网站把请求发送到被攻击者已登录的网站...
    99+
    2022-06-04
    表单 详解 Python
  • python中Flask Web 表单的使用方法介绍
    目录简介普通表单提交Flask-WTF基础使用Flask-WTF处理表单Flask消息闪现文件上传文件上传的另一种写法简介 表单的操作是Web程序开发中最核心的模块之一,绝大多数的动...
    99+
    2024-04-02
  • 使用Python的Flask框架表单插件Flask-WTF实现Web登录验证
    表单是让用户与我们的网页应用程序交互的基本元素。Flask 本身并不会帮助我们处理表单,但是 Flask-WTF 扩展让我们在我们的 Flask 应用程序中使用流行的 WTForms 包。这个包使得定义表单...
    99+
    2022-06-04
    表单 插件 框架
  • 在Python的Flask框架中构建Web表单的教程
    尽管Flask的request对象提供的支持足以处理web表单,但依然有许多任务会变得单调且重复。表单的HTML代码生成和验证提交的表单数据就是两个很好的例子。 Flask-WTF扩展使得处理web表单能获...
    99+
    2022-06-04
    表单 框架 教程
  • python web开发-flask中使
    SqlAlchemy是一个python的ORM框架。在flask中有一个flask-sqlalchemy的扩展,使用起来很方便。1.       创建一个sqlalchemy的Model模块创建一个models.py的模块创建model的时...
    99+
    2023-01-31
    python web flask
  • 怎么使用Python Web的Flask
    这篇文章主要介绍“怎么使用Python Web的Flask”,在日常操作中,相信很多人在怎么使用Python Web的Flask问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用Python Web的Fl...
    99+
    2023-06-02
  • Python如何使用Web框架Flask开发项目
    一、简介Flask是一个轻量级的基于Python的web框架。这份文档中的代码使用 Python 3 运行。 建议在 linux 下实践本教程中命令行操作、执行代码。二、安装通过pip3安装Flask即可:$ sudo pip3 insta...
    99+
    2023-05-14
    Python web Flask
  • 在Python的Flask中使用WTForms表单框架的基础教程
    下载和安装 安装 WTForms 最简单的方式是使用 easy_install 和 pip: easy_install WTForms # or pip install WTForms 你可以从 P...
    99+
    2022-06-04
    表单 基础教程 框架
  • Web微框架Flask如何安装使用
    这篇文章主要为大家展示了“Web微框架Flask如何安装使用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Web微框架Flask如何安装使用”这篇文章吧。前言:Flask 是一个 Python ...
    99+
    2023-06-21
  • 怎么使用Flask编写Python Web API
    这篇文章主要介绍了怎么使用Flask编写Python Web API,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Python 是一个以语法简洁著称的高级的、面向对象的程序语...
    99+
    2023-06-16
  • Flask wtforms实现表单验证使用
    目录wtforms 使用1(简单版): 使用2(复杂版): wtforms 安装:pip3 install wtforms 使用1(简单版): from flask impo...
    99+
    2024-04-02
  • 如何使用bootstrap3.0中的表单
    这篇文章主要介绍“如何使用bootstrap3.0中的表单”,在日常操作中,相信很多人在如何使用bootstrap3.0中的表单问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
    99+
    2024-04-02
  • Python使用Web框架Flask开发项目
    目录一、简介二、安装三、从 Hello World 开始3.1 Hello World3.2 修改Flask的配置3.3 调试模式3.4 绑定IP和端口3.5 本节源码四、获取 UR...
    99+
    2024-04-02
  • Python Flask JinJa2语法如何使用
    这篇文章主要介绍“Python Flask JinJa2语法如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python Flask JinJa2语法如...
    99+
    2023-07-05
  • 一个基于flask的web应用诞生 使用模板引擎和表单插件(2)
    经过了第一章的内容,已经可以做出一些简单的页面,首先用这种方式做一个登录页面,首先要创建一个login的路由方法: @app.route("/login",methods=["GET"]) def lo...
    99+
    2022-06-04
    表单 插件 模板
  • python的简单web框架flask快速实现详解
    目录简介web框架的重要组成部分快速上手flaskflask的第一个应用flask中的路由不同的http方法静态文件使用模板总结简介 python可以做很多事情,虽然它的强项在于进...
    99+
    2023-02-07
    python web框架flask python web框架
  • 怎么使用Flask实现简单的车牌识别Web应用
    这篇文章主要介绍了怎么使用Flask实现简单的车牌识别Web应用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么使用Flask实现简单的车牌识别Web应用文章都会有所收获,下面我们一起来看看吧。Flask框架...
    99+
    2023-07-05
  • jinja2如何在Flask中使用
    jinja2如何在Flask中使用?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1、控制结构 {% %}2、变量取值 {{ }}jinja2模板中使用 {{ }} 语法表示...
    99+
    2023-06-14
  • Python flask sqlalchemy的简单使用及常用操作
    目录前言flask sqlalchemy的配置使用sqlalchemy的增删改查查询数据增加数据修改数据删除数据总结前言 说到面向对象,大家都不陌生。关系型数据库也是后端日常用来存储...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作