文章目录

  • 一.flask集成bootstrap
    • 1. 什么是Bootstrap?
    • 2. Flask中如何集成Bootstrap?
    • 3. Flask-Bootstrap实现了什么?
  • 二.Flask中集成的web表单处理
    • 1. 为什么使用Flask-WTF?
    • 2. 什么是表单处理?
    • 3. 常见的Field类
    • 4.flask-wtf的使用流程
    • 在设计的页面里实现表单
  • 三、Flask中集成邮件发送

一.flask集成bootstrap

安装flask-bootstrap

pip install flask-bootstrap

1. 什么是Bootstrap?

Bootstrap(http://getbootstrap.com/)是 Twitter 开发的一个开源框架,它提供的用户界面组件可用于创建整洁且具有吸引力的网页,而且这些网页还能兼容所有现代 Web 浏览器。

2. Flask中如何集成Bootstrap?

使用 pip 安装Flask-Bootstrap 的 Flask 扩展,简化集成的过程。

from flask_bootstrap import Bootstrap
bootstrap = Bootstrap(app)

3. Flask-Bootstrap实现了什么?

  • 利用 Jinja2 的模板继承机制,让程序扩展一个具有基本页面结构的基模板,其中
    就有用来引入 Bootstrap 的元素。
    { % extends “bootstrap/base_other.html” % }

  • 基模板中定义了可在衍生模板中重定义的块。
    块名 说 明
    doc 整个 HTML 文档
    html_attribs 标签的属性
    html 标签中的内容
    head 标签中的内容
    title 标签中的内容<br/> metas 一组 标签<br/> styles 层叠样式表定义<br/> body_attribs 标签的属性<br/> body 标签中的内容<br/> navbar 用户定义的导航条<br/> content 用户定义的页面内容<br/> scripts 文档底部的 JavaScript 声明

  • 程序需要向已经有内容的块中添加新内容,必须使用 Jinja2 提供的 super() 函数。

{% block scripts %}
{{ super() }}
<script type="text/javascript" src="my-script.js"></script>
{% endblock %}

回顾一下super函数

class Animal(object):def __init__(self, name):self.name = namedef eat(self):print("%s正在吃。。。。。。" %(self.name))class Cat(Animal):# 1. 猫有两个属性, name, agedef __init__(self, name, age):# 执行父类的构造方法;super(Cat, self).__init__(name)self.age = age# 2. 猫在chi的时候, 显示两次, # "%s正在吃。。。。。。"# "%s正在吃鱼。。。。。。"def eat(self):super(Cat, self).eat()print("%s正在吃鱼。。。。。。" %(self.name))cat = Cat("粉条", 5)
cat.eat()

输出:

把上一篇博客的程序copy到今日新建的flask项目中
然后在终端查看bootstrap自己定义好的框架

自带的base.html文件中有许多模块,把这个文件作为基模板,然后自己的base.html根据基模板的模块填充内容。自带的base.html中有自定义的内容,比如style中已经添加了样式,如果我们想在这个样式的基础上增加样式,可以用super()继承的方法。
base.html

{% extends 'bootstrap/base.html' %}{% block styles %}{#  先继承父类的css样式导入   #}{{ super() }}<link rel="stylesheet" href="{{ url_for('static', filename='css/main.css') }}">
{% endblock %}{% block navbar %}<nav class="navbar navbar-default"><div class="container-fluid"><!-- Brand and toggle get grouped for better mobile display --><div class="navbar-header"><button type="button" class="navbar-toggle collapsed" data-toggle="collapse"data-target="#bs-example-navbar-collapse-1" aria-expanded="false"><span class="sr-only">Toggle navigation</span><span class="icon-bar"></span><span class="icon-bar"></span><span class="icon-bar"></span></button><a class="navbar-brand" href="#">Todo</a></div><!-- Collect the nav links, forms, and other content for toggling --><div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1"><ul class="nav navbar-nav"><li class="active"><a href="#">主页 <span class="sr-only">(current)</span></a></li><li><a href="{{ url_for('list') }}">用户信息</a></li><li><a href="#">监控</a></li><li><a href="#">新闻</a></li><li><a href="#">音乐</a></li><li><a href="#">电影</a></li></ul><ul class="nav navbar-nav navbar-right">{#       分类讨论:1. 如果没有登录, 显示登录和注册按钮;2. 如果登录成功, 显示用户名称和注销按钮#}{% if not session.user %}<li><a href="{{ url_for('login') }}">登录</a></li><li><a href="{{ url_for('register') }}">注册</a></li>{% else %}<li class="dropdown"><a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button"aria-haspopup="true"aria-expanded="false">当前用户:{{ session.user }} <span class="caret"></span></a><ul class="dropdown-menu"><li role="separator" class="divider"></li><li><a href="{{ url_for('logout') }}">注销</a></li></ul></li>{% endif %}</ul></div><!-- /.navbar-collapse --></div><!-- /.container-fluid --></nav>{#让每个页面都可以获取闪现信息闪现#}{% for item in get_flashed_messages() %}<div class="alert alert-warning alert-dismissible" role="alert"><button type="button" class="close" data-dismiss="alert" aria-label="Close"><spanaria-hidden="true">&times;</span></button>{{ item }}</div>{% endfor %}
{% endblock %}

在statics目录下,新建main.css文件,把样式存进入。

main.css

.navbar {font-size: 130%;background: whitesmoke;margin-top: 10px;padding-top: 5px;box-shadow: 2px 2px 2px 2px lightgray;height: 60px;
}

app.py

import os
from flask import Flask, render_template, request, redirect, url_for, flash, session
from functools import wraps
from flask_bootstrap import Bootstrap
users = [{'username': 'root','password': 'root'},{'username': 'hello','password': 'root'},]# 实现用户注册, 用户登录, 用户注销, 用户查看;
app = Flask(__name__)
app.config['SECRET_KEY'] = 'westos'
bootstrap = Bootstrap(app)
def is_login(f):"""用来判断用户是否登录成功"""@wraps(f)def wrapper(*args, **kwargs):# 判断session对象中是否有seesion['user'],# 如果包含信息, 则登录成功, 可以访问主页;# 如果不包含信息, 则未登录成功, 跳转到登录界面;;if session.get('user', None):return f(*args, **kwargs)else:flash("用户必须登录才能访问%s" % (f.__name__))return redirect(url_for('login'))return wrapperdef is_admin(f):"""用来判断用户是否登录成功"""@wraps(f)def wrapper(*args, **kwargs):# 判断session对象中是否有seesion['user']等于root,# 如果包含信息, 则登录成功, 可以访问主页;# 如果不包含信息, 则未登录成功, 跳转到登录界面;;if session.get('user', None) == 'root':return f(*args, **kwargs)else:flash("只有管理员root才能访问%s" % (f.__name__))return redirect(url_for('login'))return wrapper# 面试常问: 复习: 1. 装饰器的工作原理;  2. 如果有多个装饰器, 运行流程是怎样的?
@app.route('/')
@is_login
def index():return render_template('index.html')@app.route('/register/', methods=['GET', 'POST'])
def register():if request.method == 'POST':username = request.form.get("username", None)password = request.form.get('password', None)# 当所有的信息遍历结束, 都没有发现注册的用户存在, 则将注册的用户添加到服务器, 并跳转登录界面;for user in users:if user['username'] == username:return render_template('register.html', message="用户%s已经存在" % (username))else:users.append(dict(username=username, password=password))# return redirect('/login/')# 出现一个闪现信息;flash("用户%s已经注册成功, 请登录....." % (username), category='info')return redirect(url_for('login'))return render_template('register.html')@app.route('/login/', methods=['GET', 'POST'])
def login():if request.method == 'POST':username = request.form.get("username", None)password = request.form.get('password', None)# 当所有的信息遍历结束, 都没有发的用户存在, 则将注册的用户添加到服务器, 并跳转登录界面;for user in users:if user['username'] == username and user['password'] == password:#  将用户登录的信息存储到session中;session['user'] = usernamereturn redirect(url_for('index'))else:# 出现一个闪现信息;flash("用户%s密码错误, 请重新登录....." % (username))return redirect(url_for('login'))return render_template('login.html')@app.route('/logout/')
def logout():#  将用户存储到session中的信息删除;session.pop('user')flash("注销成功........")return redirect(url_for('login'))@app.route('/delete/<string:username>/')
def delete(username):for user in users:# 用户存在, 则删除;if username == user['username']:users.remove(user)flash("删除用户%s成功" % (username))# else:#     flash("用户%s不存在" % (username))# 删除成功, 跳转到/list/路由中.....return redirect(url_for('list'))@app.route('/list/')
@is_login
@is_admin
def list():return render_template('list.html',users=users)@app.route('/upload/', methods=['POST', 'GET'])
def upload():if request.method == 'POST':# 获取用户上传的文件对象f = request.files['faceImg']# 获取上传文件的文件名# print(f.filename)# 获取当前项目的目录位置;basepath = os.path.dirname(__file__)# print(__file__)       # /root/PycharmProjects/day34/app.py# print(basepath)       # /root/PycharmProjects/day34# /root/PycharmProjects/day34/static/img/face/xxx.png# 拼接路径, 保存到本地的位置;filepath = os.path.join(basepath, 'static', 'img', 'face', f.filename)# 保存文件f.save(filepath)flash("上传文件%s成功" % (f.filename))return redirect(url_for('upload'))else:return render_template('upload.html')if __name__ == '__main__':app.run()

二.Flask中集成的web表单处理

flask-wtf
- 避免重复操作, 表单操作很多;
- 防止表单遭遇跨站请求伪造(csrf===cross-site request forgery);

1. 为什么使用Flask-WTF?

request对象公开了所有客户端发送的请求信息。特别是request.form可以访问POST请求提交的表单数据。
尽管Flask的request对象提供的支持足以处理web表单,但依然有许多任务会变得单调且重复。
表单的HTML代码生成和验证提交的表单数据就是两个很好的例子。

优势:
Flask-WTF扩展使得处理web表单能获得更愉快的体验。该扩展是一个封装了与框架无关的WTForms包的Flask集成。

2. 什么是表单处理?

在网页中,为了和用户进行信息交互总是不得不出现一些表单。
flask设计了WTForm表单库来使flask可以更加简便地管理操作表单数据。
WTForm中最重要的几个概念如下:

1). Form类,开发者自定义的表单必须继承自Form类或者其子类。
Form类最主要的功能是通过其所包含的Field类提供对表单内数据的快捷访问方式。

2). 各种Field类,即字段。一般而言每个Field类都对应一个input的HTML标签。
比如WTForm自带的一些Field类比如BooleanField就对应,
SubmitField就对应等等。

3). Validator类。这个类用于验证用户输入的数据的合法性。
比如Length验证器可以用于验证输入数据的长度,
FileAllowed验证上传文件的类型等等。

另外,flask为了防范csfr(cross-site request forgery)攻击,
默认在使用flask-wtf之前要求app一定要设置过secret_key。
最简单地可以通过app.config[‘SECRET_KEY’] = 'xxxx’来配置。

3. 常见的Field类

PasswordField   密码字段,自动将输入转化为小黑点
  DateField   文本字段,格式要求为datetime.date一样
  IntergerField   文本字段,格式要求是整数
  DecimalField   文本字段,格式要求和decimal.Decimal一样
  FloatField   文本字段,值是浮点数
  BooleanField   复选框,值为True或者False
  RadioField   一组单选框
  SelectField   下拉列表,需要注意一下的是choices参数确定了下拉选项,
但是和HTML中的 标签一样,其是一个tuple组成的列表,
可以认为每个tuple的第一项是选项的真正的值,而第二项是alias。
  MultipleSelectField  可选多个值的下拉列表

Validator是验证函数:
Validator是验证函数,把一个字段绑定某个验证函数之后,flask会在接收表单中的数据之前对数据做一个验证,
如果验证成功才会接收数据。验证函数Validator如下,具体的validator可能需要的参数不太一样,这里只给出
一些常用的,更多详细的用法可以参见wtforms/validators.py文件的源码,参看每一个validator类需要哪些参数:

*基本上每一个validator都有message参数,指出当输入数据不符合validator要求时显示什么信息。

Email  
验证电子邮件地址的合法性,要求正则模式是.+@([.@][^@]+)$
  EqualTo  
比较两个字段的值,通常用于输入两次密码等场景,可写参数fieldname,
不过注意其是一个字符串变量,指向同表单中的另一个字段的字段名
  IPAddress  
验证IPv4地址,参数默认ipv4=True,ipv6=False。如果想要验证ipv6可以
设置这两个参数反过来。
  Length  
验证输入的字符串的长度,可以有min,max两个参数指出要设置的长度下限和上限,
注意参数类型是字符串,不是INT!!
  NumberRange  
验证输入数字是否在范围内,可以有min和max两个参数指出数字上限下限,注意参数
类型是字符串,不是I数里可以设置%(min)s和%(max)s两个格式化部分,来告诉前端
这个范围到底是多少。其他validator也有这种类似的小技巧,可以参看源码。
  Optional  
无输入值时跳过同字段的其他验证函数
  Required  
必填字段
  Regexp  
用正则表达式验证值,参数regex=‘正则模式’
  URL  
验证URL,要求正则模式是[a-z]+://(?P<host>[/:]+)(?P:[0-9]+)?
(?P /.*)?$
  AnyOf  
确保值在可选值列表中。
  NoneOf  
确保值不在可选值列表中

4.flask-wtf的使用流程

# 1). 编写forms.py文件, 定义一个关于表单的类;(***注意: 一定要有提交的按钮);
# 2). 业务逻辑文件app.py中,- 实例化表单类;  form = RegisterForm()- 验证表单内容是否提交成功?   form.validate_on_submit():- 获取表单里面的内容(两种方法):- 通过request对象获取: request.form['key值'];- 通过form对象获取: form.key值.data# 3). 表现逻辑文件wtf.html中:- 导入wtf模块: {% import "bootstrap/wtf.html" as wtf %}- 自动生成表单对应的html:  {{ wtf.quick_form(form) }}

在设计的页面里实现表单

首先安装flask_wtf

pip install flask_wtf

form.py,注意这里作为表单的前端的显示逻辑

# 专门存储表单的操作
from flask_wtf import FlaskForm
from wtforms import StringField, PasswordField, SubmitField, \RadioField, SelectField, SelectMultipleField, TextAreaField
from wtforms.validators import DataRequired, EqualTo, Length, Email, Regexpclass RegisterForm(FlaskForm):# StringField <input type='text' name='name' required># PasswordField <input type='password' name='password' required>name = StringField(label="用户名",# 验证: 用户名不能为空的validators=[DataRequired(), ])password = PasswordField(label="密码",validators=[DataRequired(),# 验证密码长度是否为6~8之间, 如果不是, 则报错;Length(6, 16, message="密码格式不正确"),])repassword = PasswordField("确认密码",validators=[DataRequired(),# 验证当前表单输入的内容和password这个表单输入的内容是否一致, 如果不一致, 报错;EqualTo('password', message="密码不一致")])phone = StringField(label="电话号码",validators=[DataRequired(),# 验证当前表单输入的电话号码是否符合首位为1,由11位数字组成的正则表达式, 如果不是, 则报错;Regexp(r'1\d{10}', message="电话号码格式错误!")])# 可以实现单选按钮, 但是不美观,# gender = RadioField(#     label="性别",#     coerce=int,#     choices=[(1, "男"), (2, "女")]## )gender = SelectField(label="性别",coerce=int,choices=[(1, "男"), (2, "女")])tech = SelectMultipleField(label="擅长领域",coerce=int,choices=[(1, 'python'), (2, 'linux'), (3, 'java'), (4, 'php'), (5, 'ruby'), (6, 'c++')])submit = SubmitField(label="注册")"""# 单选框<form>男:  <input type="radio" name="gender"  value="1">女:  <input type="radio" name="gender"  value="2"></form>"""submit = SubmitField(label="发送")

wtf.html

{% extends 'base.html' %}
{#导入模块, 并重命名为wtf#}
{% import "bootstrap/wtf.html" as wtf %}
{% block title %} wtf测试页面{% endblock %}
{% block content %}<div class="container" style="margin-top: 50px"><div class="col-lg-8 col-lg-offset-2"><h1>注册-wtf测试</h1>{#   根据后台传递过来的form对象生成对应的html代码;           #}{{ wtf.quick_form(form) }}</div></div>
{% endblock %}

app.py
新定一个wtf函数处理表单

import osfrom flask import Flask, render_template, request, redirect, url_for, flash, session
from functools import wraps
from flask_bootstrap import Bootstrapdef is_login(f):"""用来判断用户是否登录成功"""@wraps(f)def wrapper(*args, **kwargs):# 判断session对象中是否有seesion['user'],# 如果包含信息, 则登录成功, 可以访问主页;# 如果不包含信息, 则未登录成功, 跳转到登录界面;;if session.get('user', None):return f(*args, **kwargs)else:flash("用户必须登录才能访问%s" % (f.__name__))return redirect(url_for('login'))return wrapperdef is_admin(f):"""用来判断用户是否登录成功"""@wraps(f)def wrapper(*args, **kwargs):# 判断session对象中是否有seesion['user']等于root,# 如果包含信息, 则登录成功, 可以访问主页;# 如果不包含信息, 则未登录成功, 跳转到登录界面;;if session.get('user', None) == 'root':return f(*args, **kwargs)else:flash("只有管理员root才能访问%s" % (f.__name__))return redirect(url_for('login'))return wrapper# 面试常问: 复习: 1. 装饰器的工作原理;  2. 如果有多个装饰器, 运行流程是怎样的?
@app.route('/')
@is_login
def index():return render_template('index.html')@app.route('/register/', methods=['GET', 'POST'])
def register():if request.method == 'POST':username = request.form.get("username", None)password = request.form.get('password', None)# 当所有的信息遍历结束, 都没有发现注册的用户存在, 则将注册的用户添加到服务器, 并跳转登录界面;for user in users:if user['username'] == username:return render_template('register.html', message="用户%s已经存在" % (username))else:users.append(dict(username=username, password=password))# return redirect('/login/')# 出现一个闪现信息;flash("用户%s已经注册成功, 请登录....." % (username), category='info')return redirect(url_for('login'))return render_template('register.html')@app.route('/login/', methods=['GET', 'POST'])
def login():if request.method == 'POST':username = request.form.get("username", None)password = request.form.get('password', None)# 当所有的信息遍历结束, 都没有发的用户存在, 则将注册的用户添加到服务器, 并跳转登录界面;for user in users:if user['username'] == username and user['password'] == password:#  将用户登录的信息存储到session中;session['user'] = usernamereturn redirect(url_for('index'))else:# 出现一个闪现信息;flash("用户%s密码错误, 请重新登录....." % (username))return redirect(url_for('login'))return render_template('login.html')@app.route('/logout/')
def logout():#  将用户存储到session中的信息删除;session.pop('user')flash("注销成功........")return redirect(url_for('login'))@app.route('/delete/<string:username>/')
def delete(username):for user in users:# 用户存在, 则删除;if username == user['username']:users.remove(user)flash("删除用户%s成功" % (username))# else:#     flash("用户%s不存在" % (username))# 删除成功, 跳转到/list/路由中.....return redirect(url_for('list'))@app.route('/list/')
@is_login
@is_admin
def list():return render_template('list.html',users=users)@app.route('/upload/', methods=['POST', 'GET'])
def upload():if request.method == 'POST':# 获取用户上传的文件对象f = request.files['faceImg']# 获取上传文件的文件名# print(f.filename)# 获取当前项目的目录位置;basepath = os.path.dirname(__file__)# print(__file__)       # /root/PycharmProjects/day34/app.py# print(basepath)       # /root/PycharmProjects/day34# /root/PycharmProjects/day34/static/img/face/xxx.png# 拼接路径, 保存到本地的位置;filepath = os.path.join(basepath, 'static', 'img', 'face', f.filename)# 保存文件f.save(filepath)flash("上传文件%s成功" %(f.filename))return  redirect(url_for('upload'))else:return  render_template('upload.html')@app.route('/wtf/', methods=['GET', 'POST'])
def wtf():from forms import RegisterForm# 1. 实例化表单, 将来传递到前端, 进行生成对应的html;form = RegisterForm()# 2. 判断HTTP请求方式, 返回不同的内容# 第一个判断: 是否为post请求? 判断提交的数据是否符合form表单定义的验证?# if request.method == 'POST':#     print(request.form['name'])#     return  'post'if form.validate_on_submit():username = request.form['name']password = request.form['password']gender = request.form['gender']tech = request.form['tech']# 当所有的信息遍历结束, 都没有发现注册的用户存在, 则将注册的用户添加到服务器, 并跳转登录界面;for user in users:if user['username'] == username:flash(message="用户%s已经存在" % (username))return redirect(url_for('wtf'))else:users.append(dict(username=username, password=password))# return redirect('/login/')# 出现一个闪现信息;flash("用户%s已经注册成功, 请登录....." % (username))return redirect(url_for('login'))return render_template("wtf.html",form=form)

三、Flask中集成邮件发送

发送邮件的时候需要设置什么?
- 发件人账户
- 密码
- 收件人
- 邮件标题
- 邮件正文
- QQ邮件服务器的域名或者IP;

安装flask_mail

pip install flask_mail

打开pop3和smtp服务。将收到的密码保存起来。

把这个代码加入app.py文件中

from flask_mail import Mail, Message
from flask import Flask, render_template# 配置发送邮件的相关信息;
# 指定邮件服务器的域名或者IP
app.config['MAIL_SERVER'] = 'smtp.qq.com'# 指定端口, 默认25, 但qq邮箱默认为 端口号465或587;
app.config['MAIL_PORT'] = 465
app.config['MAIL_USE_SSL'] = True
app.config['MAIL_USERNAME'] = '登陆邮箱用的帐号'
# 此处的密码并非邮箱登录密码, 而是开启pop3
app.config['MAIL_PASSWORD'] = "个人密码"def send_mail(to,subject,template,**kwargs):mail = Mail(app)# app的应用上下文with app.app_context():msg = Message(subject=subject,sender='501713254@qq.com',recipients=to,# body=render_template(template+'.txt',**kwargs),html=render_template(template+'.html',**kwargs))mail.send(msg)@app.route('/mail/', methods=['GET', 'POST'])
def mail():# 实例化表单form = MailForm()if form.validate_on_submit():# 获取用户提交的数据;toEmails = form.toEmails.data.split(',')toFilename = form.toFilename.datatry:send_mail(toEmails, "西部开源邮件测试", toFilename)except Exception as e:flash("邮件发送失败, 失败原因: %s!" %(e))else:flash("邮件发送成功!")return  redirect(url_for('mail'))return  render_template('send_mail.html',form = form)

新建一个send_mail.html在statics中

{% extends 'base.html' %}
{% import "bootstrap/wtf.html" as wtf %}
{% block title %} 发送邮件 {% endblock %}
{% block content %}<div class="container"><div class="col-lg-8 col-lg-offset-2"><h1>mail</h1><hr/>{{ wtf.quick_form(form) }}</div></div>
{% endblock %}

form.py添加

class MailForm(FlaskForm):tomails = TextAreaField(label='接收的邮箱地址',validators=[DataRequired()],description='每个邮箱地址之间用逗号分隔')tofilename = SelectField(label='邮件内容',choices=[('company','公司简介'),('course','课程简介')],)submit = SubmitField(label='发送')

课程介绍course.html和公司简介company.html作为邮件发送的内容。
course.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
<h1>课程</h1>
</body>
</html>

company.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
<h1 style="color: green">公司简介</h1>
</body>
</html>

这样就可以实现群发邮件公司简介/课程介绍等

python-flask(二)集成bootstrap、集成web表单、集成邮件发送相关推荐

  1. php电子邮箱表单,php 邮件发送表单数据 | 同路吧

    使用PHP 向一个指定的邮箱发送数据是非常简单的一件事情,以至于你可能会想,为什么人们不每天用 它呢?PHP 提供的mail()函数使用四个参数:收信人,主题,邮件信息和附加的邮件头.通过这个简短的教 ...

  2. php电子邮箱表单,带邮件发送功能的表单(form.php)

    意见反馈表单 意见反馈表单 if(isset($_post["suggestion"])==true) //如果表单已填写完毕且提交,发送邮件 { $to="shb@su ...

  3. flask基础十四之wtf表单

    Web表单 Web 表单是 Web 应用程序的基本功能. 它是HTML页面中负责数据采集的部件.表单有三个部分组成:表单标签.表单域.表单按钮.表单允许用户输入数据,负责HTML页面数据采集,通过表单 ...

  4. Python Flask学习_使用Flask-wtf和web表单

    HTML中的<form> 元素表示表单,表单用于收集用户输入. 之前,学习使用request.form获取表单数据.但是有些任务重复单调,可以实现自动化管理,比如 :生成表单的HTML代码 ...

  5. Flask开发系列之Web表单

    Flask开发系列之Web表单 简单示例 from flask import Flask, request, render_templateapp = Flask(__name__) @app.rou ...

  6. Flask之Web表单使用

    Web表单使用 @(Flask) request对象包含客户端发出的所有请求信息. request.form能获取POST请求中提交的表单数据. 使用的包 Flask-WTF可以把处理Web表单的过程 ...

  7. 第四章 WEB表单(二)

    一. 重定向和用户会话 WEB表单(一)最后部分,当我们提交表单后,点击浏览器的刷新按钮时,看到一个警告"再次提交表单之前进行确认".这是因为刷新浏览器时会重新发送之前发送过的请求 ...

  8. Python Flask实现最简单的 Web

    Python Flask实现最简单的 Web 现在使用 Flask 实现一个最简单的 Web . 一.进入开发虚拟环境 在开始开发之前,需要先进入对应的虚拟环境. 现在,创建了一个名字叫 FlaskP ...

  9. Flask Web表单

    title: flask学习笔记 subtitle: 3. flask Web表单 date: 2018-12-14 10:17:28 --- Web表单 HTML表单是用户和web站点或应用程序之间 ...

最新文章

  1. Python创建删除文件(或文件夹)
  2. 发一个统计项目代码行数的Java代码
  3. boost::local_time模块实现打印本地日期时间的测试程序
  4. hdu 5112 A Curious Matt
  5. python 换脸 github_人脸识别和换脸相关深度学习开源项目github汇总
  6. idea调试怎么跳出循环_IDEA调试技巧条件断点实现步骤详解
  7. mysql中sql语句使用_mysql数据库中用到sql语句
  8. 解决vue视图不渲染
  9. 刚看了一个视频,介绍了实体店十几种线上线下引流方法
  10. 「HNOI 2015」实验比较
  11. sqlserver 2005 快速插入数据
  12. 如何编写自己的C语言头文件
  13. 电容式触摸按键原理调研总结
  14. Python金融大数据分析——第11章 统计学(2)投资组合优化 笔记
  15. put与mput_ftpput命令详解 ftp put命令使用哪个端口?
  16. 移动硬盘损坏怎么恢复?看完再也不怕丢失数据
  17. Spring Boot与安全(安全、Spring Security)
  18. echart 地图加阴影效果 四川地图为例
  19. 【浙大翁恺】Java程序设计入门笔记
  20. 关于SQLite数据库 字段 DateTime 类型

热门文章

  1. Android项目实战——一个简单的记事本程序
  2. 数字电路的一些基本知识
  3. c3po数据库连接池简单配置
  4. 三年的php简历_【完整模板】PHP工程师简历-简洁橙色-1-3年经验-Word简历模板
  5. java 文件尾部_java 在file的尾部添加数据的两种方法总结
  6. 35Java抽象类与抽象方法
  7. es6转es5 的6种方式
  8. 如何解决mac拔掉耗电量太大的设备以重新启用usb设备
  9. 区块链技术如何运用到知识产权的全生命周期
  10. STM32电路设计之最小系统