目录
一、flash消息闪现
二、Flask-WTF实现表单
三、flask中使用数据库
一、flash消息闪现
1.利用flash可以给模板传递消息,flash-->需要对内容进行加密,要设置secret_key,用于加密信息的混淆
app.secret_key='itheima'
flash(u'参数不完整')
flash(u'密码不一致')
2.在模板中需要遍历消息
{#使用遍历获取闪现的消息#}
{% for message in get_flashed_messages() %}
? ? {{message}}
{% end for %}
二、Flask-WTF实现表单
1.建立表单类,继承flask_wtf中的FlaskForm?
2.在WTForms支持的常见HTML标准字段
字段对象 | 说明 | StringField() | 文本字段 | PasswordField() | 密码文本字段 | BooleanField() | 复选框,值为True或False | FileField() | 文件上传字段 | DataField() | 文本字段,datatime.data文本格式 | intrgerField() | 文本字段,值为整数 | FloatField() | 文本字段,值为浮点数 | SubmitField() | 表单提交按钮 | SelectField() | 下拉列表 |
?3.WTForm常用验证函数
验证函数 | 说明 | DataRequired | 确保字段中有数据 | EqualTo | 比较两个字段的值,常用于比较两次密码输入 | Length | 验证输入的字符串长度 | NumberRange | 验证输入的值在数字范围内 | URL | 验证URL | AnyOf | 验证输入值在可选列表中 | NoneOf | 验证输入值不在可选列表中 |
4.代码实现:?
'''
使用WTF实现表单
自定义表单类
定义根路由视图函数,生成表单对象,获取表单数据,进行表单数据验证
'''
class LoginForm(FlaskForm):
username=StringField('用户名:',validators=[DataRequired()])#u中文转码
password=PasswordField('密码:',validators=[DataRequired()])
password2=PasswordField('确认密码:',validators=[DataRequired(),EqualTo('password','密码填入不一致')])
submit=SubmitField('提交')
@app.route('/form',methods=['GET','POST'])
def login():
login_form=LoginForm()
#1.判断请求方式
if request.method=='POST':
#2.获取请求的参数
username = request.form.get('username')
password = request.form.get('password')
password2 = request.form.get('password2')
#3.验证参数,一句话实现验证
if login_form.validate_on_submit():
print (username,password)
return 'success'
else:
flash('参数有误')
<form method="post">
{{ form.csrf_token() }}
{{ form.username.label }}{{ form.username }}<br>
{{ form.password.label }}{{ form.password }}<br>
{{ form.password2.label }}{{ form.password }}<br>
{{ form.submit }}
注:csrf_token的作用是当我们get表单页面时,服务器返回页面的同时也会向前端返回一串随机字符,post提交时服务器会验证这串字符来确保用户是在服务端返回的表单页面中提交的数据
三、flask中使用数据库
1.flask-SQLAlchemy扩展:SQLAlchemy是一个关系型数据库框架,也是对数据库的抽象,通过Python对象来操作数据库,它提供了高层ORM和底层的原生数据库操作,flask-sqlalchemy是一个简化了SQLAlchemy操作的flask扩展
2.安装:
pip install flask-sqlalchemy
3.flask的数据库设置:Flask-SQLAlchemy中,数据库使用URL指定,并且程序使用的数据库必须保存到Flask配置对象的SQLALCHEMY_DATABASE_URL键中
app.config['SQLALCHEMY_DATABASE_URL']='mysql://root:mysql@127.0.0.1:3006/test'
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
app = Flask(__name__)
#配置数据库地址
app.config['SQLALCHEMY_DATABASE_URL']='mysql://root:mysql@127.0.0.1:3006/flask_sql_demo'
#跟踪数据库修改--》不建议开启
app.config['SQLALCHEMY_TRACK_MODIFICATIONS']=False
db=SQLAlchemy(app)
@app.route('/')
def hello_world():
return 'Hello World!'
if __name__ == '__main__':
app.run(debug=True)
|