本文实例讲述了Sanic框架路由用法。分享给大家供大家参考,具体如下:
前面一篇《Sanic框架安装与简单入门》简单介绍了Sanic框架的安装与基本用法,这里进一步学习Sanic框架的路由。
简介
Sanic是一个类似Flask的Python 3.5+ Web服务器,它的写入速度非常快。除了Flask之外,Sanic还支持异步请求处理程序。这意味着你可以使用Python 3.5中新的闪亮的异步/等待语法,使你的代码非阻塞和快速。
前言:Sanic最低支持Python 3.5,如果需要学习Sanic,请先下载版本不低于3.5的Python包
路由
路由允许用户为不同的URL端点指定不同的处理函数,我们取出上一篇《Sanic框架安装与简单入门》的路由为例:
from sanic.response import json @app.route("/") async def hello_sanic(request): data = json({"code":0}) return data
当我们在浏览器输入http://localhost:5000/时,根据路由匹配到处理函数hello_sanic
,最终返回JSON对象。Sanic处理函数必须使用语法async def
来定义,因为它们是异步行数。
请求参数
Sanic处理函数带有一个支持请求的参数,即上面的request
参数。如果需要制定一个参数,我们可以使用尖角括号将其括起来,如下所示:
from sanic.response import json @app.route("/hello/<name>") async def hello(request,name): return json({"name":name})
此时我们再浏览器输入:http://localhost:5000/hello/laowang时,Sanic将会根据路由匹配处理函数,从而返回数据。此时,我们需要对参数进行指定类型,可以在路由中的参数后面加上:type
,假设传入一个age参数,为int类型,路由可以这么写:/hello/<age:int>
。代码如下:
from sanic.response import json @app.route("/hello/<age:int>") async def hello_age(request,age): return json({"age":age})
此时就可以指定用户传入指定类型的参数了,如果类型不对,将报404错误。
请求类型
对于Sanic处理网络请求,也举了不少例子,可是这些都是GET请求,那我们该如何定义一个POST请求呢?与Flask相同,@app.route
支持一个可选参数methods
,methods
可传入一个列表类型,如此,它将允许处理函数使用列表中的任何HTTP方法。
from sanic.response import json @app.route("/post/json_data",methods=["POST"]) async def post_json(request): """ POST请求 json数据 """ return json(request.json) @app.route("/post/form_data",methods=["POST"]) async def post_form(request): """ POST请求 form表单数据 """ return json(request.form) @app.route("/get/data",methods=["GET"]) async def get_data(request): """ GET请求 """ return json(request.args)
因为GET请求时默认的,所以,如果需要定义一个GET请求,那么methods参数可以无需传递。@app.route
还支持另一个可选参数host,这限制了一条到所提供的主机或主机的路由。
from sanic.response import text @app.route("/hello/host",host="abc.com") async def hello_host(request): return text("hello host")
在浏览器中访问此路由,如果主机头不匹配abc.com,那么将会报404错误。
路由的装饰器写法除了上面介绍的那种,还可以将其简写,如下所示:
from sanic.response import json @app.get("/short/get") async def short_get(request): return json(request.args) @app.post("/short/post") async def short_post(request): return json(request.json)
add_route方法
通常我们指定一个路由,都是通过@app.route
装饰器,然而,这个装饰器实际上只是这个add_route
方法的一个包装器,使用方法如下:
async def add_get_route(request): """ 添加GET请求 """ return json(request.args) async def add_get_type_route(request,age): """ 添加带指定类型的参数的GET请求 """ return json({"age":age}) async def add_post_route(request): """ 添加POST请求 """ return json(request.json) app.add_route(add_get_route,"/add_get_route") app.add_route(add_get_type_route,"/add_get_type_route/<age:int>") app.add_route(add_post_route,"/add_post_route",methods=["POST"])
重定向
Sanic提供了一个url_for基于处理程序方法名称生成URL的方法。如果你想要避免将URL路径硬编码到你的应用程序当中,这很有用。例如:
from sanic.response import text,redirect @app.route("/url_info") async def url_info(request): url = app.url_for('post_handler',name="laozhang",arg_one="one",arg_two="two") print(url) return redirect(url) @app.route("/post_handler/<name>") async def post_handler(request,name): print(request.args) return text("name:{}".format(name))
url_for使用注意:第一个参数为重定向URL的路由名称(默认为函数名称),并非URL名称。另外我们可以将一些请求参数指派到url_for方法中,上面例子重定向后的url将会是:
/post_handler/laozhang"htmlcode">app.url_for("post_handler",favorite=["football","bastketball"]) # /post_handler"font-size: medium">唯一URL在Flask中,我们顶一个一个
URL
为/get
,此时我们访问/get将可以访问成功,如果输入/get/
将会返回404错误,这就是唯一URL。在Sanic中同样拥有此功能,我们可以通过配置strict_slashes
参数来实现:from sanic.response import text @app.route("/get",strict_slashes=True) async def get(request): return text("it is ok!")注意:
strict_slashes
默认值为None,如果不设置的话,访问/get
或/get/
都将可以访问成功,那么这就不是唯一URL了。在上面的例子中,我们将此值设置为True,此时我们输入/get/
,将会返回一个404错误,这样就完成了一个唯一URL的实现。如果我们需要将所有的URL都设置成为唯一URL,我们可以这样:
from sanic import Sanic from sanic.response import text app = Sanic(strict_slashes=True) @app.route("/hello") async def hello(request): return text("it is ok!") @app.route("/world") async def world(request): return text("it is ok!")
/hello
和world
都变成了唯一URL。如果我们只需要部分URL设置成唯一URL,我们可以在
@app.route
装饰器中传入strict_slashes
,并设置为Flase,那么此URL将不是唯一URL。或者我们也可以定义一个蓝图,如下:from sanic import Blueprint ss_bp = Blueprint("aaa",strict_slashes=False) @ss_bp.route("/world") async def world(request): return text("it is ok!") app.blueprint(ss_bp)即使你在app中传递了参数
strict_slashes=True
,那么也没有用,所有通过此蓝图定义的URL都将不是唯一URL。自定义路由名称
通常一个路由的名称为程序处理方法名称,即
函数.__name__
生成的,用于可以传递一个name参数到装饰器中来修改它的名称,如下:from sanic.response import text @app.route("/get",name="get_info") async def get(request): return text("it is ok!")此时
url_for
中传递的将不是函数名称,而是name的值:print(app.url_for("get_info")) # /get同样,也适用于蓝图:
from sanic import Blueprint ss_bp = Blueprint("test_bp") @ss_bp.route("/get",name="get_info") async def get(request): return text("it is ok!") app.blueprint(ss_bp) print(app.url_for("test_bp.get_info"))静态文件的URL
我们需要构建一个特定的URL来访问我们需要的HTML,此时我们可以这样:
from sanic import Sanic,Blueprint app = Sanic() app.static("/home","./static/home.html")此时我们在访问
/home
就可以链接到我们指定的HTML中了,此方法同样适用于蓝图。
CompositionView
除了上面那几种定义路由的方法之外,Sanic还提供了
CompositionView
来动态添加路由:from sanic.views import CompositionView from sanic.response import text async def post_handler(request): print(request.json) return text('it is ok!') view = CompositionView() view.add(["POST"],post_handler) app.add_route(view,"/post_info")如此,就构造了一个POST请求的接口
处理器装饰器
由于Sanic处理程序是简单的Python函数,因此可以用与Flask类似的修饰符应用于它们。一个典型的用例就是当一些代码想要在处理程序的代码执行之前执行:
from sanic.response import text def is_authorized(): return True def authorized(func): async def wrapper(request,*args,**kwargs): is_auth = is_authorized() if is_auth: response = await func(request,*args,**kwargs) return response else: return text("it is not authorized") return wrapper @app.route("/get_user_info") @authorized async def get_user_info(request): return text("get_user_info")更多关于Python相关内容可查看本站专题:《Python入门与进阶经典教程》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python文件与目录操作技巧汇总》
希望本文所述对大家Python程序设计有所帮助。
Sanic框架,路由
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]