【flask笔记3】

目录

一、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)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

In my opinion

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值