sanic官方文档解析之路由
1,路由,路由相当于一个网址的地址,来确定网址的位置和唯一性
当http://server.url/被允许访问服务器,当最后的"/"通过路由匹配到了业务逻辑处理的函数,将会返回一个json对象
Sanic处理函数必须被定义使用async def语法,作为异步处理的函数
- 1.1请求参数的处理(Request Parametres)
Sanic框架天生自带一个基本的支持参数的路由
为了特殊的参数,支持引用尖括号来携带参数类似:<PARAM>,请求参数将会被通过路由处理函数作为关键字参数
- 1.2参数的特殊类型
参数的特殊形式在后边增加一个,参数的数据类型(:type)在参数的后边,尖括号的里边,如果参数和数据类型不匹配,Sanic框架会抛出一个NotFound的例子,会在url上显示404: Page not found
这个int和 number有什么区别,未完待续...?
这个[A-z]和[A-z]+和[A-z0-9]{0,4}应该是和正则匹配的规则是一致的,未完待续...?
- 1.3HTTP请求的方式
通常,一个路由定义一个URL将会被可用的仅仅只能为get请求,然而,这个@app.route装饰器接收一组可供选择的参数,请求方法,在列表;写哪一个请求的方法,就会运行哪一个请求的方法.
路由里还有一个可选的host参数(可以是列表或者是一个字符串),严格的提供host或者hosts,如果没有host,将是默认是host.
也有一些快键的路由指定请求的方式,直接定义骑牛的方式,@app.get,@app.post.
- 1.4增加路由的方法
正如我们所见,路由京城被特殊的用作@app.route,装饰器,然而,这样的装饰器已经缺失装饰了app.add_route,被做作为一个追随者.,具体使用如上图
- 1.5,用url_for建立url
Sanic框架提供了一个url_for方法,是基于处理方法名称去生成url,如果你想避免在你的app中编码url的路径,你可以参考以上的处理名字.(对求的参数可以做判断筛选)内部跳转,不用客户端再发一次请求了,类似namespace
一下这几种情况牢记要使用url_for
- 通过url_for没有请求参数的关键字参数将会被包含在查询的url中
- 多个值的参数将会通过url_for来设置路由
- 还有一些特殊的参数(
_anchor
,_external
,_scheme
,_method
,_server
)通过url_for将会有特殊的url建立的方法(_method现在和你支持这样的操作并且将会忽略) - 所有有效的参数必须通过url_for去建立URL,如果没有供给一个参数,或者 参数和数据类型不搭配,将会抛出一个URLBuildError的错误
- 1.6websocket通信路由
Websocket协议的路由能够被@app.websocket装饰(直接在装饰器中,在视图函数中收发消息)
app.add_websocket_route这个方法可以被用作路由的装饰器
用请求的第一个参数处理Websocket路由被调用,并且W二本socket协议对象作为第二个参数,这个Websocket协议对象能够分别的接受和发送数据
- 1.7关于路由斜线的说明
- from sanic import Sanic, Blueprint
- from sanic.response import text
- # 实例化一个Sanic对象
- # 为所有的提供路由提供斜线的配置
- app = Sanic("test_route_strict_slash", strict_slashes=True)
- # 你可以为特殊的路由设置斜线
- @app.get("/get", strict_slashes=False)
- def handler(request):
- return text("ok")
- # 也可以为蓝图设置斜线的配置
- bq = Blueprint("test_bq_strict_slash", strict_slashes=True)
- @bq.get("/bq/get", strict_slashes=False)
- def handler(request):
- return text("ok")
- app.blueprint(bq)
- 使用定义的路由的名字
通过有一个name的参数被用来习惯性的设置成路由的名字,与此同时注册侧路由用handler.__name__的属性重写默认的路由的名字
- from sanic import Sanic, Blueprint
- from sanic.response import text
- # 实例化一个Sanic对象
- app = Sanic("test_named_route")
- @app.get("/get", name="get_handler") # 给这个路由重命名
- def handler(request):
- return text("ok")
- # 你需要使用app.url_for("get_handler")来反向解析这个路由
- # 代替app.url_for("handler")
- # 同样也为蓝图工作
- bq = Blueprint("test_named_bq")
- @bq.get("/bq/get", name="get_handler")
- def handler(request):
- return text("ok")
- app.blueprint(bq)
- # 你需要使用app.url_for("test_named_bq.get_handler)
- # 代替app.url_for("handler)
- # 不同的名称和不同的方法都能够被用于同一个url中
- @app.get("/test", name="route_test")
- def handler(request):
- return text("ok")
- @app.post("/test", name="route_test")
- def handler2(request):
- return text("ok POST")
- @app.put("/test", name="route_put")
- def handler3(request):
- return text("ok put")
- # 在url相同的情况下,你可以使用以上三只中方法中的任何一个
- app.url_for("route_test")
- # 用不同的方法处理在路由重命名一样
- # 你需要一个特殊的命名
- @app.get("/get")
- def handler(request):
- return text("ok")
- @app.post("/post", name="post_handler")
- def handler(request):
- return text("ok")
- 1.8为静态文件设置url
Sanic支持使用url_for的方法去建立静态文件的url,如果万一静态的文件指向了一个字典,这个url_for会忽略文件的参数
sanic官方文档解析之路由的更多相关文章
- sanic官方文档解析之ssl,debug mode模式和test(测试)
1,ssl 示例: 可选择的SSLContent from sanic import Sanic import ssl context = ssl.create_default_context(pur ...
- sanic官方文档解析之Deploying(部署)和Extension(扩展)
1,Deploying(部署) 通过内置的websocket可以很简单的部署sanic项目,之后通过实例sanic.Sanic,我们可以运行run这个方法通过接下来的关键字参数 host (defau ...
- sanic官方文档解析之Example(一)
1,示例 这部的文档是简单的示例集合,它能够帮助你快速的启动应用大部分的应用,这些应用大多事分类的,并且提供给ini工作的连接代码: 1.1,基础示例 这部分示例集成了提供简单sanic简单的代码 单 ...
- sanic官方文档解析之logging和request Data
1,sanic的logging: Sanic允许有做不同类型的日志(通过的日志,错误的日志),在基于Python3的日志API接口请求,你必须具备基本的Python3的日志知识,在你如果想创建一个新的 ...
- sanic官方文档解析之下载和Configuration
1,sanic框架是做什么的? sanic的官方网址:https://sanic.readthedocs.io/en/latest/ sanic框架是一个类似于flask框架的在Python3.5以上 ...
- sanic官方文档解析之Example(二)
1,通过docker部署sanic项目 通过Docker和Docker Compose部署SANIC应用程序是一项很容易实现的任务,下面的示例提供了示例simple_server.py的部署 FROM ...
- sanic官方文档解析之streaming(流动,滚动)和class_based_views(CBV的写法)
1,streaming(流媒体) 1.1请求流媒体 Sanic允许你通过流媒体携带请求数据,如下,当请求结束await request.stream.read()就会返回None,仅仅只有post请求 ...
- sanic官方文档解析之Custom Protocols(自定义协议)和Socket(网络套接字)
1,Custom Protocol:自定义协议 温馨提示:自定义协议是一个高级用法,大多数的读者不需要用到此功能 通过特殊的自定义协议,你可以改变sanic的协议,自定义协议需要继承子类asyncio ...
- sanic官方文档解析之websocket(网络套接字)和handle decorators(处理程序装饰器)
1,websocket(网络套接字) 在websocket上Sanic提供了一种简单使用的抽象化,来设置websocket(网络套接字) from sanic import Sanic from sa ...
随机推荐
- 网页QQ唤起
网页QQ唤起 <html> <head> <meta http-equiv="Content-Type" content="text/htm ...
- EasyUI combogrid 赋多个值
var values = []; for (var i = 0; i < rows.length; i++) { if (rows[i].id>0 ) { values.push('' + ...
- AJAX技术简介
AJAX 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术. 您应当具备的基础知识 在继续学习之前,您需要对下面的知识有基本的了解: HTML / XHTML CSS JavaScript ...
- servlet分析
Servlet生命周期分为三个阶段: 1,初始化阶段 调用init()方法 2,响应客户请求阶段 调用service()方法 3,终止阶段 调用destroy()方法 Servlet初始化阶段: 在 ...
- 对Netflix Ribbon的Loadbalancer类源码设计合理性的一点质疑
首先,这只是我个人的一点质疑,可能是因为我自己菜没有领悟到作者的意思,也正因此,想发出来跟大家一起探讨. 在昨晚,我因为在编写自己的开源项目的负载均衡模块(这是我开源项目的介绍:https://www ...
- 负环 BZOJ 4773
负环 [问题描述] 在忘记考虑负环之后,黎瑟的算法又出错了.对于边带权的有向图 G = (V, E),请找出一个点数最小的环,使得环上的边权和为负数.保证图中不包含重边和自环. [输入格式] 第1两个 ...
- iOS常用三方库收集
除非Pod可以直接加载到工程中的外,收集一下 https://github.com/kejinlu/KKGestureLockView 好用的手势解锁
- js动态适配移动端font-size,单位:rem
比如:目前我手中有一张psd图,大小为640*1010,适配苹果5的手机. 方法步骤: 1.我采用font-size=10px为640*1010手机的初始像素大小: 1rem=10px: 此时psd ...
- Keil建立第一个C51工程的步骤
参见51+arm开发板<使用手册.pdf> 1.“project” >> “new project” >> 新建一个用于保存工程的文件夹例如dem &g ...
- GRYZY #13. 拼不出的数
拼不出的数 lost.in/.out/.cpp [问题描述] 3 个元素的集合 {5, 1, 2} 的所有子集的和分别是 0, 1, 2, 3, 5, 6, 7, 8.发 现最小的不能由该集合子集拼出 ...