1.CBV :
 from flask import views
 
 class LoginView(views.MethodView):
  def get(self):
   return
   
  def post(self):
   return
   
 
 app.add_url_rule("/login",endpoint=None,view_func=LoginView.as_view("login"))
 
2.flash:
 from flask import flash,get_flash_messages
 
 flash("","tag")
 get_flash_messages("tag")
 
3.Flask-Session
 from flask_session import Session
 from flask import session
 
 app.config["SESSION_TYPE"] = "redis"
 app.config["SESSION_REDIS"] = Redis("127.0.0.1",6379,db=7)
 Session(app)
 
 session["user"] = "123"
 session.get("user")
 
4.WTForms - MoudelForm
 from wtfroms.fields import simple,core
 from wtfroms import Form,validators
 
 class LoginForm(Form):
  username = simple.StringFields(
   label = "" #看源码 __init__
  )
  
 
 lf = LoginForm()
 render_template("html",lf=lf)
 
 {{ lf.uername }}
 {{ lf.uername.label }}
 {{ lf.uername.errors.0 }}
 
 lf = LoginForm(request.form)
 
 if not lf.validata():
  render_template("html",lf=lf)
 
 lf.data.get("username")
 
 
**************************************************************************************************************************************
 
from flask import Flask,request,render_templatefrom flask import viewsfrom wtforms import Form #类似 form表单from wtforms.fields import simple,corefrom wtforms import validators #验证器

app=Flask(__name__)#登录页面认证class LoginForm(Form):    username=simple.StringField(        label='用户名',        validators=[            validators.DataRequired(message='不能为空'),#直接把错误写入            validators.Length(min=3,max=5,message='不能小于3位,不能大于5位')        ],        render_kw={'class':'my_username'}, #相等于自定义的类,属性    )

    password=simple.PasswordField(        label='密码',        validators=[           validators.DataRequired(message='不能为空'),            validators.length(min=6,max=6,message='密码必须为6位'),            validators.Regexp(regex='\d+',message='密码必须为数字'),        ],        render_kw={'class':'my_password'}    )

#注册页面认证class RegForm(Form):    username=simple.StringField(        label='密码',        validators=[            validators.DataRequired(message='不能为空'),            validators.Length(min=3,max=5,message='')        ],        render_kw={'class':'my_username'}    )    nickname=simple.StringField(        label='昵称',        validators=[            validators.DataRequired(message='不能为空')],        render_kw={'class':'my_nickname'}    )

    password=simple.PasswordField(        label='密码',        validators=[            validators.DataRequired(message='不能为空'),            validators.Length(min=6,max=6,message='密码必须为6位'),            validators.Regexp(regex='\d+',message='密码必须为数字')        ],        render_kw={'class':'my_password'}    )

    repassword=simple.PasswordField(        label='确认密码',        validators=[ #EqualTo 等于    与字段匹配            validators.EqualTo(fieldname='password',message='两次不一致')        ],        render_kw={'class':'my_password'}    )

    email=simple.StringField(        label='邮箱',        validators=[            validators.Email(message='格式不正确')        ],        render_kw={'class':'myemail'}    )

    #上面用simple  下面用core    gender=core.RadioField(        label='性别',        coerce=int,  #类型为int        choices=(            (1,'女'),            (2,'男')        ),        default=1  #默认为1    )

    hobby=core.SelectMultipleField(        label='爱好',        coerce=int,        choices=(            (1,'小姐姐'),            (2,'小萝莉'),            (3,'小哥哥'),            (4,'正太'),            (5,'小阿姨'),            (6,'小大叔'),        ),        default=(1,2,5)    )

    submit=simple.SubmitField(        label='提交'    )

#登录验证class LoginClass(views.MethodView):    def get(self):        froms=LoginForm()        return render_template('login.html',froms=froms)

    def post(self):        froms=LoginForm(request.form)        if froms.validate(): #django 是is_valid()            return '110'        else:            return render_template('login.html',froms=froms)

app.add_url_rule('/login',view_func=LoginClass.as_view('login'))

#注册

class RegClass(views.MethodView):

    def get(self):        froms=RegForm()        return render_template('reg.html',froms=froms)

    def post(self):        froms=RegForm(request.form)        if froms.validate():            return '120'        else:            return render_template('reg.html',froms=froms)app.add_url_rule('/reg',view_func=RegClass.as_view('reg'))

if __name__ == '__main__':    app.run(debug=True)

flask 之cbv ,flash闪现,Flask_Session,WTForms - MoudelForm的更多相关文章

  1. flask的CBV,flash,Flask-Session,及WTForms-MoudelForm

    1,CBV: from flask import vews class LoginView(views.MethodView): def get(self): return "雪雪其实也很好 ...

  2. flask模板应用-消息闪现(flash())

    消息闪现 flask提供了一个非常有用的flash()函数,它可以用来“闪现”需要提示给用户的消息,比如当用户登录成功后显示“欢迎回来!”.在视图函数调用flash()函数,传入消息内容,flash( ...

  3. Flask Flash闪现

    Flash介绍以及工作方式 flash中添加消息 取出flash中的消息 Flash介绍以及工作方式 - 介绍: flash :闪现 一个好的应用和用户界面都需要良好的反馈. 如果用户得不到足够的反馈 ...

  4. flask flask_session,WTForms

    一.Flask_session 本质上,就是是cookie 下的session存储在redis中,方便快速取得session from flask import Flask,session from ...

  5. 第十一篇 CBV和闪现

    前几篇写的都是FBV 现在可以了解一下CBV CBV 其实就是把请求方式都写到一个类中 学过django的一眼应该就明白了 from flask import Flask, render_templa ...

  6. Flask - 请求响应 | session | 闪现 | 请求扩展 | 中间件

    请求响应 flask的请求信息都在request里 flask的响应方式有四剑客,也可以自定义响应 请求相关信息 # request.method 提交的方法 # request.args get请求 ...

  7. python Flask框架CBV视图

    1.演示之前需要先写一个装饰器 # 装饰器 def wrapper(func): def inner(*args, **kwargs): print('操作函数%s之前' % func.__name_ ...

  8. flask之CBV模式

    flask_cbv.py ''' flask中的CBV模式: (1)导入views模块: from flask import views (2)定义类,继承views.MethodView类: cla ...

  9. Flask中的flash

    一.简单的使用 - 必须要设置秘钥因为flash是基于session -设置:flash('aaa') -取值:get_flashed_message() #从源码我们可以看出get_flashed_ ...

随机推荐

  1. SqlServer语句

    1.增加列 增加int列,不为空并赋默认值为0 alter table Department add Status int not null default 0 with values 2.新建表:c ...

  2. MySQL程序只mysqlbinlog详解

    mysqlbinlog命令详解 mysqlbinlog用于处理二进制的日志文件,如果想要查看这些日志文件的文本内容,就需要使用mysqlbinlog工具 用法: mysqlbinlog [option ...

  3. const引用返回值

    一.引用 引用是别名 必须在定义引用时进行初始化.初始化是指明引用指向哪个对象的唯一方法. const 引用是指向 const 对象的引用: ; const int &refVal = iva ...

  4. ML平台_Paddle参考

    PaddlePaddle源自于 2013 年百度深度学习实验室创建的 “Paddle”.当时的深度学习框架大多只支持单 GPU 运算,对于百度这样需要对大规模数据进行处理的机构,这显然远远不够,极大拖 ...

  5. 使用Vivado的block design

    使用Vivado的block design (1)调用ZYNQ7 Processing System (2)配置ZYNQ7系统 (3)外设端口配置 根据开发板原理图MIO48和MIO49配置成了串口通 ...

  6. mysql 性能

    https://blog.csdn.net/zengxuewen2045/article/category/6388631 #sda 磁盘信息dstat -D sda 3 5 #找出系统瓶颈dstat ...

  7. django 数据模型中 null=True 和 blank=True 有什么区别

    null: If True, Django will store empty values as NULL in the database. Default is False. 如果为True,空值将 ...

  8. 两招解决异常_Cannot find any information on property 'XXX' in a bean of type 'XXX'的问题

    第一招 在进行Java Web项目开发的时候,我碰到过下面这个异常: Cannot find any information on property 'XXX' in a bean of type ' ...

  9. PCM简介

    1. 差分脉冲编码调制 如果两个相邻抽样值之间的相关性很大,那么它们的差值就较小,这样,仅对差值量化可以使用较少的比特数,此即差分PCM,或DPCM. 为了理论方便,我们将采样和量化分开,并用不带上三 ...

  10. Java 线程转储 [转]

    http://www.oschina.net/translate/java-thread-dump java线程转储 java的线程转储可以被定义为JVM中在某一个给定的时刻运行的所有线程的快照.一个 ...