一、session

除请求对象之外,还有一个 session 对象。它允许你在不同请求间存储特定用户的信息。它是在 Cookies 的基础上实现的,并且对 Cookies 进行密钥签名要使用会话,你需要设置一个密钥。

  • 设置:session['username'] = 'xxx'
  • 取值:session.get['username']
  • 删除:session.pop('username', None)
from flask import Flask
from flask import render_template
from flask import session
from flask import request
from flask import redirect app = Flask(__name__) app.config.from_mapping({"SECRET_KEY":"value"}) @app.route("/login",methods=["GET","POST"])
def login():
if request.method == "POST":
username = request.form.get("username")
password = request.form.get("password")
if username == "xiaoming" and password == "":
# 登陆成功后设置session
session["userinfo"] = {"name":username}
return redirect("/")
return render_template("login.html") @app.route("/")
def index():
# 获取session
print(session["userinfo"])
return "首页" if __name__ == '__main__':
app.run()

二、flash 闪现

闪现的作用:flash设置值只能取一次

闪现的原理:利用session设置值,通过pop的方法删除并返回值,取值的时候调用session.pop()的方法将值放到flashes中,请求还在取值都从flashes中获取

'''
存一次只能取一次值,用session模拟闪现
'''
from flask import Flask,session app = Flask(__name__)
app.secret_key = "key" # 设置session需要设置secret_key @app.route("/set")
def set():
session['name'] = "xiaoming"
return "Set name" @app.route("/get")
def get():
# 删除session的键值对并取值
name = session.pop("name","")
print(name)
return name if __name__ == '__main__':
app.run()

session模拟flash

# 设置值
flash(message, category='message') # 获取值
get_flashed_messages(with_categories=False, category_filter=[])
from flask import Flask,flash,get_flashed_messages

app = Flask(__name__)
app.secret_key = "key" @app.route("/set")
def set():
flash("xiaoming") # 设置值
flash(18,"age") # 参数:message,分类
return "flash设置值" @app.route("/get")
def get():
# 取值
name = get_flashed_messages() # 按分类取值category_filter=[]
age = get_flashed_messages(category_filter=["age"])
print(name)
print(age)
return "GET" if __name__ == '__main__':
app.run()

三、中间件

app.run()        #程序的入口

run_simple(host, port, self, **options)        # run的本质是调用run_simple
# host == ip
# port == 端口
# self == app # 执行了self() 相当于执行app(),调用app的__call__方法
# app.__call__ def __call__(self, environ, start_response):
return self.wsgi_app(environ, start_response) # 相当于执行 app.wsgi_app(environ, start_response)

app.run的源码流程

'''
中间件的实现
''' from flask import Flask app = Flask(__name__) class Middleware(object):
def __init__(self,old_wsgi_app):
# 原来的wsgi_app
self.wsgi_app= old_wsgi_app def __call__(self, *args, **kwargs):
print("项目启动之前")
# wsgi_app是原来的wsgi_app
ret = self.wsgi_app(*args, **kwargs)
print("项目启动之后")
return ret if __name__ == '__main__':
# 将旧的app.wsgi_app赋值给新的app.wsgi_app
app.wsgi_app = Middleware(app.wsgi_app)
app.run() '''
* Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
项目启动之前
127.0.0.1 - - [28/Dec/2018 16:43:27] "GET / HTTP/1.1" 404 -
项目启动之后
'''

四、特殊的装饰器

@app.before_first_request # 第一次请求
@app.before_request # 每一次请求
@app.after_request # 每一次响应

注意:before_request有返回值,不走视图函数,直接走after_request
@app.template_global()
@app.template_filter()
@app.errorhandler(404)

'''
自定义装饰器实现登陆认证
''' from flask import Flask
from functools import wraps
from flask import url_for
from flask import session
from flask import render_template
from flask import request,redirect app = Flask(__name__)
app.secret_key = "key" # 自定义装饰器
def Auth_decorator(func):
@wraps(func)
def inner(*args,**kwargs):
# 访问是否携带认证,否则跳转都登陆页面
if not session.get("user",""):
return redirect("login")
ret = func(*args,**kwargs)
return ret
return inner # 登陆
@app.route("/login",endpoint="login",methods=["GET","POST"])
def login():
if request.method == "POST":
username = request.form.get("username")
password = request.form.get("password")
if username == "xiaoming" and password == "":
# 登陆成功后设置session
session["user"] = username
return redirect(url_for("myhome"))
return render_template("login.html") # 登陆成功后跳转的页面
@app.route("/home",endpoint="myhome")
@Auth_decorator
def home():
return "登陆成功的HOME页面" if __name__ == '__main__':
app.run()

自定义登陆认证的装饰器

# 模板的全局装饰器
@app.template_global()
def mysum(n1,n2):
return n1+n2 # HTML
{{ mysum(10,5) }}

@app.template_global()

# 模板的筛选器
@app.template_filter()
def myfilter(data):
return data[::2] # HTML
{{ "today hello" | myfilter() }}

模板的筛选器

# 路径不存在跳转到指定页面的装饰器
@app.errorhandler(404)
def error_page(error):
return render_template("error404.html")

路径不存在返回页面

五、路由的实现原理

不能有多个endpoint指向同一个视图函数,内部是{'endpoint':"view_func"}

app.route()
# 执行route函数
route(self, rule, **options)
# self == app
# rule == 路由 # 返回decorator函数
return decorator # decorator函数,传入视图函数
def decorator(f):
endpoint = options.pop('endpoint', None)
self.add_url_rule(rule, endpoint, f, **options)
return f # 调用add_url_rule(路由,endpoint,视图函数)
def add_url_rule(self, rule, endpoint=None, view_func=None,provide_automatic_options=None, **options):
# endpoint不能有多个视图函数,否则抛出异常
if view_func is not None:
old_func = self.view_functions.get(endpoint)
if old_func is not None and old_func != view_func:
raise AssertionError('View function mapping is overwriting an '
'existing endpoint function: %s' % endpoint)
self.view_functions[endpoint] = view_func

route源码流程

'''
根据路由原理创建Flask项目
'''
from flask import Flask # 实例化Flask对象
app = Flask(__name__) def index():
return "这是首页" # 调用app.route的核心方法,实行app.route
app.add_url_rule("/",view_func=index) if __name__ == '__main__':
app.run()

六、CBV编程

1.类继承views.MethodView
2.装饰器修饰的列表 decorators = []
3.指定路由和类 app.add_url_rule

from flask import Flask
from flask import views app = Flask(__name__) class MyView(views.MethodView):
# decorators = [] # 存放装饰器的列表
# methods = ["GET","POST"] # 请求方式列表,用于限制的 def get(self):
return "GET" def post(self):
return "POST" app.add_url_rule("/",view_func=MyView.as_view(name="index")) if __name__ == '__main__':
app.run()

七、自定义路由正则匹配

from flask import Flask,url_for
from werkzeug.routing import BaseConverter app = Flask(__name__) class RegexConverter(BaseConverter):
'''
自定义URL匹配正则表达式
''' def __init__(self,map,regex):
super(RegexConverter,self).__init__(map)
self.regex = regex def to_python(self, value):
'''
路由匹配时,匹配成功后传递给视图函数中参数的值
:param value:
:return:
'''
return value def to_url(self, value):
'''
使用url_for反向生成URL时,传递的参数经过该方法处理,返回的值用于生成URL中的参数
:param value:
:return:
'''
val = super(RegexConverter,self).to_url(value)
return val # 添加到flask中
app.url_map.converters['regex'] = RegexConverter @app.route("/index/<regex('\d+'):id>")
def index(id):
print(url_for('index',id=''))
print(type(id))
return "{}".format(id) if __name__ == '__main__':
app.run()

Flask的基础二的更多相关文章

  1. Flask框架(二)—— 反向解析、配置信息、路由系统、模板、请求响应、闪现、session

    Flask框架(二)—— 反向解析.配置信息.路由系统.模板.请求响应.闪现.session 目录 反向解析.配置信息.路由系统.模板.请求响应.闪现.session 一.反向解析 1.什么是反向解析 ...

  2. Python全栈开发【基础二】

    Python全栈开发[基础二] 本节内容: Python 运算符(算术运算.比较运算.赋值运算.逻辑运算.成员运算) 基本数据类型(数字.布尔值.字符串.列表.元组.字典) 其他(编码,range,f ...

  3. Bootstrap <基础二十九>面板(Panels)

    Bootstrap 面板(Panels).面板组件用于把 DOM 组件插入到一个盒子中.创建一个基本的面板,只需要向 <div> 元素添加 class .panel 和 class .pa ...

  4. Bootstrap <基础二十八>列表组

    列表组.列表组件用于以列表形式呈现复杂的和自定义的内容.创建一个基本的列表组的步骤如下: 向元素 <ul> 添加 class .list-group. 向 <li> 添加 cl ...

  5. Bootstrap<基础二十七> 多媒体对象(Media Object)

    Bootstrap 中的多媒体对象(Media Object).这些抽象的对象样式用于创建各种类型的组件(比如:博客评论),我们可以在组件中使用图文混排,图像可以左对齐或者右对齐.媒体对象可以用更少的 ...

  6. Bootstrap <基础二十六>进度条

    Bootstrap 进度条.在本教程中,你将看到如何使用 Bootstrap 创建加载.重定向或动作状态的进度条. Bootstrap 进度条使用 CSS3 过渡和动画来获得该效果.Internet ...

  7. Bootstrap <基础二十五>警告(Alerts)

    警告(Alerts)以及 Bootstrap 所提供的用于警告的 class.警告(Alerts)向用户提供了一种定义消息样式的方式.它们为典型的用户操作提供了上下文信息反馈. 您可以为警告框添加一个 ...

  8. Bootstrap<基础二十四> 缩略图

    Bootstrap 缩略图.大多数站点都需要在网格中布局图像.视频.文本等.Bootstrap 通过缩略图为此提供了一种简便的方式.使用 Bootstrap 创建缩略图的步骤如下: 在图像周围添加带有 ...

  9. Bootstrap <基础二十三>页面标题(Page Header)

    页面标题(Page Header)是个不错的功能,它会在网页标题四周添加适当的间距.当一个网页中有多个标题且每个标题之间需要添加一定的间距时,页面标题这个功能就显得特别有用.如需使用页面标题(Page ...

随机推荐

  1. openresty开发系列31--openresty执行流程

    openresty开发系列31--openresty执行流程 我们先看个例子 location /test {    set $a 32;    echo $a;    set $a 56;    e ...

  2. [转]windows 下 gcc/g++ 的安装

    链接地址:https://www.jianshu.com/p/ff24a81f3637 不过下载地址直接进这里就可以了:https://sourceforge.net/projects/mingw/

  3. [LeetCode] 202. Happy Number 快乐数

    Write an algorithm to determine if a number is "happy". A happy number is a number defined ...

  4. centos7升级openssh

    注意: openssl版本(openssl版本要大于1.0.1,zlib版本要大于1.1.4) 一.安装依赖包 yum -y install gcc make perl # zlib zlib-dev ...

  5. 【Python学习之十】操作数据库

    环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 python3.6 操作mysql数据库 1.安装pymysql模块p ...

  6. 查看端口被哪个程序占用的DOS命令

    netstat -aon | findstr 80Proto Local Address Foreign Address State PID==== ============ ============ ...

  7. LeetCode 75. 颜色分类(Sort Colors) 30

    75. 颜色分类 75. Sort Colors 题目描述 给定一个包含红色.白色和蓝色,一共 n 个元素的数组,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色.白色.蓝色顺序排列. 此题中, ...

  8. JavaWeb实现增删查改(图书信息管理)之删除功能实现

    —————————————————————————————————————————————————————————— 删除按钮对应的servlet -->DeleteBooks.java  ↓ ...

  9. 爬虫请求库之selenium

    一.介绍 selenium最初是一个自动化测试工具,而爬虫中使用它主要是为了解决requests无法直接执行JavaScript代码的问题 selenium本质是通过驱动浏览器,完全模拟浏览器的操作, ...

  10. TweenMax参数用法中文介绍

    TweenMax 建立在 TweenLite 和 TweenFilterLite 基础之上,因此,又揉合了这二者的功能,使得功能更加的齐备,但是如果说易用性,觉得还是 TweenLite 来得方便一些 ...