Sanic框架蓝图用法实例分析


Posted in Python onJuly 17, 2018

本文实例讲述了Sanic框架蓝图用法。分享给大家供大家参考,具体如下:

蓝图是可以用于应用程序内子路由的对象。蓝图并未向应用程序内添加路由,而是定义了用于添加路由的类似方法,然后以灵活且可插入的方式向应用程序注册路由。

蓝图对于大型应用程序尤其有用,您的应用程序可以分解成为几个小组或责任区域。

第一个蓝图

假设你在bp/bp_1.py文件下,定义了以下这么一个非常简单的蓝图:

from sanic import Blueprint
from sanic.response import text
bp = Blueprint("first_bp")
@bp.route("/get_info")
async def get_info(request):
  return text("it is ok!")

注册蓝图

定义了一个蓝图之后,必须在应用程序中注册:

from sanic import Sanic
from bp.bp_1 import bp
app = Sanic()
app.blueprint(bp)
if __name__ == "__main__":
  app.run()

如此,并将蓝图添加到应用程序当中,并注册蓝图所定义的所有路由。此时我们就可以访问/get_info就可以获取到数据了

蓝图的使用

在前面一篇《Sanic框架异常处理与中间件操作》中简单介绍了一下在路由中如何使用中间件与异常以及监听器等,这些东西在蓝图中同样可以使用:

中间件:使用蓝图可以在全局范围内注册中间件

@bp.route("/get_info")
async def get_info(request):
  return text("get_info")
@bp.middleware("request")
async def handle_md_request(request):
  print("request middleware")
@bp.middleware("response")
async def handle_md_response(request,response):
  print("response middleware")

异常:使用蓝图可以在全局范围内注册异常

from sanic.exceptions import NotFound
@bp.exception(NotFound)
async def handle_exception(request,exception):
  return text("404 exception")

静态文件:静态文件可以在蓝图前缀下全局提供

bp.static("/home","/aaa/bbb/abc.html")

监听器:如果需要在服务器启动/关闭的时候,执行一些特殊的代码,则可以使用以下监听器,可用的监听器如下:

  • before_server_start:在服务器开始接收连接之前执行
  • after_server_start:在服务器开始接收连接之后执行
  • before_server_stop:在服务器停止接收连接之前执行
  • after_server_stop:在服务器停止接收连接之后执行
@bp.listener("before_server_start")
async def before_server_start(request,loop):
  print("before server start")
@bp.listener("after_server_start")
async def after_server_start(request,loop):
  print("after server start")
@bp.listener("before_server_stop")
async def before_server_stop(request,loop):
  print("before server stop")
@bp.listener("after_server_stop")
async def after_server_stop(request,loop):
  print("after server stop")

当服务器启动时,将会依次打印如下信息:

before server start
after server start

当服务器关闭时,将会依次打印如下信息:

before server stop
after server stop

API版本控制

与手机APP对接的接口开发中,API版本控制尤为重要,针对于低版本用户(尚未升级版本的用户)所用的仍是旧的接口数据,此时开发新功能时对此模块的数据需要进行修改,可是不能影响旧版本的用户,此时我们就需要对API版本进行控制。我们可以定义两个蓝图,一个指向/v1/<route>,另一个指向/v2/<route>。当蓝图初始化时,我们可以采用一个可选参数url_prefix,该参数将被置于蓝图定义的所有路由之上,这个特性可以来实现我们的API版本控制方案:

from sanic import Blueprint
from sanic.response import text
bp1 = Blueprint("bp1",url_prefix="/v1")
bp2 = Blueprint("bp2",url_prefix="/v2")
@bp1.route("/get_data")
async def get_v1_data(request):
  return text("it is v1")
@bp2.route("/get_data")
async def get_v2_data(request):
  return text("it is v2")

此时,我们已经定义好了两个蓝图来控制两个版本,我们需要在app中注册它们:

from sanic import Sanic
from app.bp.bp_info import bp1,bp2
app = Sanic()
app.blueprint(bp1)
app.blueprint(bp2)
if __name__ == "__main__":
  app.run()

重定向

在之前的博文中,我们讲到可以使用url_for基于处理程序方法名称生成URL,然后使用redirect进行重定向,在蓝图中同样使用:

from sanic.response import text,redirect
@bp.route("/")
async def handle_root(request):
  # bp为定义蓝图实例中的name
  url = request.app.url_for("bp.get_info",name="laozhang")
  return redirect(url)
@bp.route("/get_info/<name>")
async def get_info(request,name):
  return text("name:{}".format(name))

更多关于Python相关内容可查看本站专题:《Python入门与进阶经典教程》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python文件与目录操作技巧汇总》

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
下载给定网页上图片的方法
Feb 18 Python
解决Pycharm运行时找不到文件的问题
Oct 29 Python
Django 开发环境配置过程详解
Jul 18 Python
基于python监控程序是否关闭
Jan 14 Python
Python如何使用paramiko模块连接linux
Mar 18 Python
Python面向对象程序设计之静态方法、类方法、属性方法原理与用法分析
Mar 23 Python
如何实现更换Jupyter Notebook内核Python版本
May 18 Python
利用python对excel中一列的时间数据更改格式操作
Jul 14 Python
Python logging日志库空间不足问题解决
Sep 14 Python
详解Python利用configparser对配置文件进行读写操作
Nov 03 Python
python报错TypeError: ‘NoneType‘ object is not subscriptable的解决方法
Nov 05 Python
Python find()、rfind()方法及作用
Dec 24 Python
PyCharm设置SSH远程调试的方法
Jul 17 #Python
Flask框架通过Flask_login实现用户登录功能示例
Jul 17 #Python
pycharm远程linux开发和调试代码的方法
Jul 17 #Python
Flask框架各种常见装饰器示例
Jul 17 #Python
详解基于django实现的webssh简单例子
Jul 17 #Python
Python爬虫之网页图片抓取的方法
Jul 16 #Python
python编辑用户登入界面的实现代码
Jul 16 #Python
You might like
FirePHP 推荐一款PHP调试工具
2011/04/23 PHP
深入理解php的MySQL连接类
2013/06/07 PHP
Android ProgressBar进度条和ProgressDialog进度框的展示DEMO
2013/06/19 PHP
thinkphp的静态缓存用法分析
2014/11/29 PHP
Laravel 5.3 学习笔记之 配置
2016/08/28 PHP
thinkphp在php7环境下提示Cannot use ‘String’ as class name as it is reserved的解决方法
2016/09/30 PHP
PHP实现加密文本文件并限制特定页面的存取的效果
2016/10/21 PHP
有关PHP 中 config.m4 的探索
2020/08/26 PHP
jquery select(列表)的操作(取值/赋值)
2009/08/06 Javascript
JS 用6N±1法求素数 实例教程
2009/10/20 Javascript
jQuery filter函数使用方法
2014/05/19 Javascript
jquery $(document).ready()和window.onload的区别浅析
2015/02/04 Javascript
jQuery+Ajax实现无刷新操作
2016/01/04 Javascript
JavaScript类型系统之正则表达式
2016/01/05 Javascript
jQuery模仿阿里云购买服务器选择购买时间长度的代码
2016/04/29 Javascript
JavaScript数据类型转换的注意事项
2016/07/31 Javascript
JS对象深度克隆实例分析
2017/03/16 Javascript
Javascript查看大图功能代码实现
2020/05/07 Javascript
python下10个简单实例代码
2017/11/15 Python
Python中的heapq模块源码详析
2019/01/08 Python
Python操作Excel把数据分给sheet
2020/05/20 Python
Python爬取某平台短视频的方法
2021/02/08 Python
Hobbs官方网站:英国奢华女性时尚服装
2020/02/22 全球购物
俄罗斯在线大型超市:ТутПросто
2021/01/08 全球购物
奥林匹亚体育:Olympia Sports
2020/12/30 全球购物
.NET常见笔试题集
2012/12/01 面试题
经销商会议欢迎词
2014/01/11 职场文书
大学校园毕业自我鉴定
2014/01/15 职场文书
社区网格化管理实施方案
2014/03/21 职场文书
县人大领导班子四风对照检查材料思想汇报
2014/10/09 职场文书
2014年就业工作总结
2014/11/26 职场文书
计划生育汇报材料
2014/12/26 职场文书
4S店销售内勤岗位职责
2015/04/13 职场文书
2015年幼儿园中班工作总结
2015/04/25 职场文书
医院中层管理人员培训心得体会
2016/01/11 职场文书
Python实现信息管理系统
2022/06/05 Python