flask 之cbv ,flash闪现,Flask_Session,WTForms - MoudelForm
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")
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")
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的更多相关文章
- flask的CBV,flash,Flask-Session,及WTForms-MoudelForm
1,CBV: from flask import vews class LoginView(views.MethodView): def get(self): return "雪雪其实也很好 ...
- flask模板应用-消息闪现(flash())
消息闪现 flask提供了一个非常有用的flash()函数,它可以用来“闪现”需要提示给用户的消息,比如当用户登录成功后显示“欢迎回来!”.在视图函数调用flash()函数,传入消息内容,flash( ...
- Flask Flash闪现
Flash介绍以及工作方式 flash中添加消息 取出flash中的消息 Flash介绍以及工作方式 - 介绍: flash :闪现 一个好的应用和用户界面都需要良好的反馈. 如果用户得不到足够的反馈 ...
- flask flask_session,WTForms
一.Flask_session 本质上,就是是cookie 下的session存储在redis中,方便快速取得session from flask import Flask,session from ...
- 第十一篇 CBV和闪现
前几篇写的都是FBV 现在可以了解一下CBV CBV 其实就是把请求方式都写到一个类中 学过django的一眼应该就明白了 from flask import Flask, render_templa ...
- Flask - 请求响应 | session | 闪现 | 请求扩展 | 中间件
请求响应 flask的请求信息都在request里 flask的响应方式有四剑客,也可以自定义响应 请求相关信息 # request.method 提交的方法 # request.args get请求 ...
- python Flask框架CBV视图
1.演示之前需要先写一个装饰器 # 装饰器 def wrapper(func): def inner(*args, **kwargs): print('操作函数%s之前' % func.__name_ ...
- flask之CBV模式
flask_cbv.py ''' flask中的CBV模式: (1)导入views模块: from flask import views (2)定义类,继承views.MethodView类: cla ...
- Flask中的flash
一.简单的使用 - 必须要设置秘钥因为flash是基于session -设置:flash('aaa') -取值:get_flashed_message() #从源码我们可以看出get_flashed_ ...
随机推荐
- mysql 5.45 以后需要 需要 安全套接字问题
错误异常:According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established ...
- dubbo的三种运行方式
1.Tomcat容器内启动 pom.xml 文件中 <build> <resources> <resource> <directory>src/main ...
- Hadoop HDFS 文件块大小
HDFS 文件块大小 HDFS中的文件在物理上是分块存储(block),块的大小可以通过配置参数( dfs.blocksize)来规定,默认大小在hadoop2.x版本中是128M,老版本中是64M ...
- swiper4 一个页面多个轮播
<div class="swiper-container"> <div class="swiper-wrapper"> <div ...
- android 逆向
用到两个工具 :dex2jar和jd-gui 1,重命名ContactManager.apk为ContactManager.zip并解压得到文件classes.dex: 2,解压dex2jar-0.0 ...
- https 不检验证书
System.Net.ServicePointManager.ServerCertificateValidationCallback += (s, cert, chain, sslPolicyErro ...
- C++进阶--命名空间和关键字using
//############################################################################ /* * C++关键字:using * * ...
- QTreeWidget的Item点击事件
转载:cw123458945 #!/usr/bin/env python import sys from PyQt4.QtCore import SIGNAL from PyQt4.QtGui imp ...
- 解析流中的Xml文件时,报错:java.net.MalformedURLException: no protocol
原来的代码: // 创建DocumentBuilder对象 DocumentBuilder b = a.newDocumentBuilder(); // 通过DocumentBuilder对象的par ...
- Flume的Channel
一.Memory Channel 事件将被存储在内存中(指定大小的队列里) 非常适合那些需要高吞吐量且允许数据丢失的场景下 属性说明: 二.JDBC Channel 事件会被持久化(存储)到可靠的数据 ...