1,异常

异常是从处理请求内部抛出来的,并且通过Sanic自动的被处理异常,,异常用第一个参数携带异常信息,还可以接受在HTTP响应中要传递回的状态代码。引发异常

  • 1.1引发异常

自动触发异常,,简单的额使用raise从sanic.exceptions的模块中抛出相关的异常即可

 

你也可以使用中止函数的状态码,来抛异常 ,如上图所示:

  • 1.2异常处理

@app.exception被使用来重写处理默认的异常,,这个装饰器期望一系列的异常作为参数去处理,你可以通过SanicException去抓住异常,装饰异常处理函数必须携带请求和异常对象在参数中.

你也可以增加异常处理.

有些情况下,,你也许想添加一些更详细的错误信息处理函数,可以默认提供,在那种情况下,你可以对Sanic的错误语法进行子类的划分.  

  • 1.3有用的例外

一些有用的例外,目前如上所示:

  • NotFound:当找不到适合请求的路由时调用
  • ServerError:当服务器发生故障时调用。如果用户代码中出现异常,通常会发生这种情况
  • 有关引发异常 的完整列表,请参考sanic.exception模块.

2, 中间件:

中间件是用在请求到来之前和响应请求之后,,中间件可以被用来修改 氢气去和 响应,在中间件处理函数中

另外,Sanic提供监听运行的代码的多种要点在你懂得的应用中

Sanic中有2中类型的中间件,请求和响应,者两种响应都用@app.middleware装饰器来装饰.用装饰器的参数是字符串来代替request或者是response.

from sanic import Sanic
from sanic.response import text # 实例化Sanic对象
app = Sanic(__name__) @app.middleware("request")
async def print_on_request(request):
print("i print when a request is received by the server") @app.middleware("response")
async def print_on_response(request ,response):
print("i print when a response is returned by the server")
  • 2.1修改请求和响应

中间件能够修改给定的请求和响应的参数,只要中间件没有返回请求或者响应

from sanic import Sanic

# 实例化Sanic对象
app = Sanic(__name__) @app.middleware("request")
async def add_key(request):
# 增加请求对象的关键字,就像地点的对象
request["foo"] = "bar" @app.middleware("response")
async def custom_banner(request, response):
response.headers["Server"] = "Fake-Server" @app.middleware("response")
async def prevent_xss(request, response):
response.headers["x-xss-protection"] = "1; mode-block" app.run(host="0.0.0.0", port=8000, debug=True)

以上代码应用在中间件中,第一个中间件增加一个新的关键字foo到请求request中,中间件的运行是因为请求对象的主体类似字典对象,第二个中间件定制的横幅将会改变HTTP响应头为Fake-Server,最后一个中间件是为了增加HTTP头防止xss攻击,这些2个功能在函数返回一个 response响应的时候调用

  • 2.2早期的回应

如果中间件返回一个httpresponse对象,那么请求将停止处理并返回响应。如果在到达相关的用户路由处理程序之前请求出现这种情况,则永远不会调用该处理程序。返回响应还将阻止任何其他中间件的运行

from sanic import Sanic
from sanic.response import text # 实例化一个Sanic对象
app = Sanic(__name__) @app.middleware("request")
async def halt_request(request):
return text("i halted the request") @app.middleware("response")
async def halt_response(request, response):
return text("i halted the response")

3,监听

如你想执行启动/拆卸的代码作为你服务器的启动或者关闭,你可以使用以下几种监听模式:

  • before_server_start
  • after_server_start
  • before_server_stop
  • after_server_stop

这些监听的方式被作为装饰在接收app项目也异步循环的功能函数的装饰器

from sanic import Sanic

# 实例化一个Sanic对象
app = Sanic(__name__) @app.listener("before_server_start")
async def setup_db(app, loop):
app.db = await db_setupb() @app.listener("after_server_start")
async def notify_server_started(app, loop):
print("Server successfully started!") @app.listener("before_server_stop")
async def notify_server_stopping(app, loop):
print("Server shutting down!") @app.listener("after_server_stop")
async def close_db(app, loop):
await app.db.close()

监听同样也可以用register_listener方法来注册一个监听者,如果你定义你的监听者在另一个模块中,此外在你实例化你的app中.

from sanic import Sanic

# 实例化一个Sanic对象
app = Sanic() async def setup_db(app, loop):
app.db = await db_setup() app.register_listener(setup_db, "before_server_start") # 注册监听者(在服务启动前)

如果要计划在循环启动后运行后台任务,Sanic提供了add_task方法很容易启动后台程序.

from sanic import Sanic
import asyncio # 实例化Sanic对象
app = Sanic() async def notify_server_started_after_five_second():
await asyncio.sleep(5)
print("Server successfully started!")
# 用app来增加异步功能函数的任务
app.add_task(notify_server_started_after_five_second())

Sanic将会尝试去自动的 诸如到app中,作为一个参数添加到任务中.

import asyncio
from sanic import Sanic # 实例化一个Sanic对象
app = Sanic()
async def notify_server_started_after_five_second(app):
await asyncio.sleep(5)
print(app.name)
# 用app来增加异步函数功能
app.add_task(notify_server_started_after_five_second)

或者你可以明确地作用于app,也是一样的效果.

from sanic import Sanic
import asyncio # 实例化一个Sanic对象
app = Sanic() async def notify_server_started_after_five_seconds(app):
await asyncio.sleep(5)
print(app.name)
app.add_task(notify_server_started_after_five_seconds(app))

sanic官方文档解析之Exception和Middleware,Listeners的更多相关文章

  1. sanic官方文档解析之Custom Protocols(自定义协议)和Socket(网络套接字)

    1,Custom Protocol:自定义协议 温馨提示:自定义协议是一个高级用法,大多数的读者不需要用到此功能 通过特殊的自定义协议,你可以改变sanic的协议,自定义协议需要继承子类asyncio ...

  2. sanic官方文档解析之Example(二)

    1,通过docker部署sanic项目 通过Docker和Docker Compose部署SANIC应用程序是一项很容易实现的任务,下面的示例提供了示例simple_server.py的部署 FROM ...

  3. sanic官方文档解析之Deploying(部署)和Extension(扩展)

    1,Deploying(部署) 通过内置的websocket可以很简单的部署sanic项目,之后通过实例sanic.Sanic,我们可以运行run这个方法通过接下来的关键字参数 host (defau ...

  4. sanic官方文档解析之Example(一)

    1,示例 这部的文档是简单的示例集合,它能够帮助你快速的启动应用大部分的应用,这些应用大多事分类的,并且提供给ini工作的连接代码: 1.1,基础示例 这部分示例集成了提供简单sanic简单的代码 单 ...

  5. sanic官方文档解析之路由

    1,路由,路由相当于一个网址的地址,来确定网址的位置和唯一性 当http://server.url/被允许访问服务器,当最后的"/"通过路由匹配到了业务逻辑处理的函数,将会返回一个 ...

  6. sanic官方文档解析之logging和request Data

    1,sanic的logging: Sanic允许有做不同类型的日志(通过的日志,错误的日志),在基于Python3的日志API接口请求,你必须具备基本的Python3的日志知识,在你如果想创建一个新的 ...

  7. sanic官方文档解析之下载和Configuration

    1,sanic框架是做什么的? sanic的官方网址:https://sanic.readthedocs.io/en/latest/ sanic框架是一个类似于flask框架的在Python3.5以上 ...

  8. sanic官方文档解析之ssl,debug mode模式和test(测试)

    1,ssl 示例: 可选择的SSLContent from sanic import Sanic import ssl context = ssl.create_default_context(pur ...

  9. sanic官方文档解析之streaming(流动,滚动)和class_based_views(CBV的写法)

    1,streaming(流媒体) 1.1请求流媒体 Sanic允许你通过流媒体携带请求数据,如下,当请求结束await request.stream.read()就会返回None,仅仅只有post请求 ...

随机推荐

  1. 2014 ACM/ICPC Asia Regional 北京 Online

    G - Grade Ted is a employee of Always Cook Mushroom (ACM). His boss Matt gives him a pack of mushroo ...

  2. ffmpeg的函数av_samples_get_buffer_size分析,对齐的意思

    /* * 此函数只应用于音频. * 计算出:要把一系列的样本保存起来,需要多大的缓存. * sample,单个通道的单次采样所得到的样本数据. * planar,和yuv存储格式一样,声音也分平面(p ...

  3. Codeforces Round #407 (Div. 2) B+C!

    B. Masha and geometric depression 被这个题坑了一下午,感觉很水,一直WA在第14组,我那个气啊,结束后发现第14组有点小争议,于是找出题人解释,然后出题人甩给了我一段 ...

  4. 九度oj 题目1151:位操作练习

    题目描述: 给出两个不大于65535的非负整数,判断其中一个的16位二进制表示形式,是否能由另一个的16位二进制表示形式经过循环左移若干位而得到. 循环左移和普通左移的区别在于:最左边的那一位经过循环 ...

  5. 九度oj 题目1104:整除问题

    题目描述: 给定n,a求最大的k,使n!可以被a^k整除但不能被a^(k+1)整除. 输入: 两个整数n(2<=n<=1000),a(2<=a<=1000) 输出: 一个整数. ...

  6. linux 中 stat 函数的用途和使用方法

    stat 函数讲解 表头文件:    #include <sys/stat.h> #include <unistd.h> 定义函数:    int stat(const cha ...

  7. 降雨量 BZOJ 1067

    降雨量 [问题描述] 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年的降雨量严格小于X年.例如2002,2003,20 ...

  8. Lumia 1020 诞生:诺基亚拍照技术的一次狂欢

    它在手机发展史上留下一长串坚实的脚印,拥趸遍及世界.它从巅峰滑落,但从未放弃向过去致敬的机会. 2002 年,作为世界上第一款内置摄像头拍照手机,诺基亚 7650 的横空出世将手机行业硬生生推上一个新 ...

  9. 【shell】shell编程(一)-入门

    如今,不会Linux的程序员都不意思说自己是程序员,而不会shell编程就不能说自己会Linux.说起来似乎shell编程很屌啊,然而不用担心,其实shell编程真的很简单.背景 什么是shell编程 ...

  10. [Bzoj3676][Apio2014]回文串(后缀自动机)(parent树)(倍增)

    3676: [Apio2014]回文串 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 3396  Solved: 1568[Submit][Statu ...