一文带你快速了解Python史上最快Web框架

文章目录

  • 1. 写在前面
  • 2. Sanic框架简介
    • 2.1 背景
    • 2.2 特征与优势
  • 3. Sanic框架实战
    • 3.1. 安装Sanic
    • 3.2. Demo案例编写

【作者主页】:吴秋霖
【作者介绍】:Python领域优质创作者、阿里云博客专家、华为云享专家。长期致力于Python与爬虫领域研究与开发工作!
【作者推荐】:对JS逆向感兴趣的朋友可以关注《爬虫JS逆向实战》,对分布式爬虫平台感兴趣的朋友可以关注《分布式爬虫平台搭建与开发实战》
还有未来会持续更新的验证码突防、APP逆向、Python领域等一系列文章

1. 写在前面

  在Python的Web开发领域内这些年框架也是层出不穷,早已不再局限于Django、Flask、Tornado甚至是后面的FastApi

曾经的玄冥二老也慢慢退居幕后,新的时代都是年轻人天下!这个时代的年轻王者无疑是Sanic

在网上有对Python所有的Web框架做过测试,可以看到曾经的老牌框架已经垫底:
在这里插入图片描述

官方地址:Sanic

从Python3+后,各种异步很火,所以说相对于传统的同步框架在某些特定的场景下更加适应,因为同步与异步在并发、实时性上还是有很大差异的

2. Sanic框架简介

2.1 背景

  Sanic最早由ChannelCat团队开发,旨在提供一个高性能的异步Web框架。其灵感来自于Flask,并在异步编程的基础上进行了优化。Sanic利用Python3.5引入的async/await语法,使得开发者可以编写快速且高效的异步Web应用程序

2.2 特征与优势

  江湖中的朋友们一直都称之为Python史上最强且最快的Web框架,并且流行度越来越广泛

  • 高性能:利用异步编程的优势,允许处理大量并发请求而不会阻塞线程,从而实现高性能和低延迟
  • 轻量级:核心设计非常简洁,不依赖大量的外部库,使得其体积小巧,易于部署和维护
  • 路由功能:提供了简单易用的路由功能,让开发者能够轻松地定义URL和处理请求的处理程序
  • 中间件支持:支持中间件,开发者可以在请求和响应处理过程中添加额外的逻辑
  • WebSocket支持:对WebSocket 提供了良好的支持,允许构建实时的双向通信应用程序

3. Sanic框架实战

3.1. 安装Sanic

  首先我们使用pip命令安装Sonic:

pip3 install sanic

在这里插入图片描述

3.2. Demo案例编写

如下是一个简单的Sanic应用程序,实现了基本的路由与请求:

# -*- coding: utf-8 -*-
from sanic import Sanic
from sanic import response

app = Sanic("sanic_demo")

@app.route("/")
def run(request):
    return response.text("Hello World !")

if __name__ == '__main__':
    app.run(host="0.0.0.0", port=8001, debug=True)

在终端中运行上面应用程序:

在这里插入图片描述

程序运行后我们在浏览器地址中访问http://127.0.0.1:8001就可以看到返回的信息了

接下来我们编写一个稍微复杂的案例代码,这是一个简化的在线商店系统,包括用户注册、商品管理、购物车等功能。实际真实的商城会更加复杂

# -*- coding: utf-8 -*-
from sanic import Sanic, response
from sanic.exceptions import NotFound, ServerError
from sanic_jwt import Initialize, protected
from sanic_session import Session, InMemorySessionInterface

app = Sanic("OnlineStore")
app.config.SECRET_KEY = "supersecretkey"

Initialize(app, authenticate=None)

Session(app, interface=InMemorySessionInterface())

users_db = {}
products_db = {}
carts_db = {}

# Routes
@app.route("/")
async def home(request):
    return response.text("欢迎来到爬虫商店!")

@app.route("/register", methods=["POST"])
async def register(request):
    data = request.json
    username = data.get("username")
    password = data.get("password")

    if username in users_db:
        return response.json({"message": "Username already exists"}, status=400)

    users_db[username] = password
    return response.json({"message": "Registration successful"})

@app.route("/login", methods=["POST"])
async def login(request):
    data = request.json
    username = data.get("username")
    password = data.get("password")

    if username not in users_db or users_db[username] != password:
        return response.json({"message": "Invalid credentials"}, status=401)

    token = app.auth.jwt_encode(request, {"username": username})
    return response.json({"token": token})

@app.route("/products", methods=["GET"])
@protected()
async def get_products(request):
    return response.json({"products": products_db})

@app.route("/add_to_cart", methods=["POST"])
@protected()
async def add_to_cart(request):
    data = request.json
    username = request.ctx.get("user").get("username")
    product_id = data.get("product_id")
    quantity = data.get("quantity", 1)

    if product_id not in products_db:
        return response.json({"message": "Product not found"}, status=404)

    if username not in carts_db:
        carts_db[username] = {}

    if product_id not in carts_db[username]:
        carts_db[username][product_id] = quantity
    else:
        carts_db[username][product_id] += quantity

    return response.json({"message": "Product added to cart"})

@app.route("/view_cart", methods=["GET"])
@protected()
async def view_cart(request):
    username = request.ctx.get("user").get("username")

    if username not in carts_db:
        return response.json({"cart": {}}, status=200)

    return response.json({"cart": carts_db[username]})

# Error Handlers
@app.exception(NotFound)
async def not_found(request, exception):
    return response.json({"message": "Not Found"}, status=404)

@app.exception(ServerError)
async def server_error(request, exception):
    return response.json({"message": "Internal Server Error"}, status=500)

if __name__ == "__main__":
    app.run(host="0.0.0.0", port=8000, debug=True)

在上面的代码中使用了Sanic框架处理用户注册、登录、商品管理、购物车等功能。同时,使用了Sanic JWT进行用户身份验证和会话管理

最后总结一下:

Sanic适用于需要高性能、实时性的应用,以及小型到中型项目

Django适用于大型、全功能的Web应用程序,尤其是需要使用内置功能快速构建应用的场景

Flask适用于对框架提供的功能有更大灵活性和控制需求,以及对轻量级框架的偏好

  好了,到这里又到了跟大家说再见的时候了。创作不易,帮忙点个赞再走吧。你的支持是我创作的动力,希望能带给大家更多优质的文章

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/175692.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

4.2V升多串LED驱动升压6V9V12V恒流点灯

4.2V升多串LED驱动升压6V9V12V恒流点灯 探索WT7012,这款引领潮流的升压转换器,其强大功能将彻底改变您的LED驱动格局。可以轻松驾驭多达7串白光LED,展现出无与伦比的驱动能力。 无论是单节锂电池还是多节锂电池供电产品,宽电压3…

老知识复盘-SQL从提交到执行到底经历了什么 | 京东云技术团队

一、什么是SQL sql(Structured Query Language: 结构化查询语言)是高级的费过程化编程语言,允许用户在高层数据结构上工作, 是一种数据查询和程序设计语言, 也是(ANSI)的一项标准的计算机语言. but… 目前仍然存在着许多不同版本的sql语言,为了与ANSI标准相兼容, 它们必须以相…

特征工程完整指南 - 第二部分

苏米特班迪帕迪亚 照片由Dan Cristian Pădureş在Unsplash上拍摄 一、说明 DATA,通常被称为原油,需要经过加工和清洁才能有效地用于各种用途。正如我们不直接使用来自其来源的石油一样,数据也经过类似的处理以提取其真正价值。 二、特征选…

数据结构——栈的详细介绍

数据结构——栈 一、栈的结构和概念二、 栈的两种构建方式①、用数组进行构建②、用链表进行构建 三、栈的创建四、栈的初始化五、栈的销毁六、压栈七、出栈八、判空九、获取栈顶元素十、获取栈的size 一、栈的结构和概念 栈:栈是一种特殊的线性表,其只…

【数据分享】全国1-5级流域、河流矢量数据与水体分布、五级水系数据、八级水系边界范围矢量数据

全国3级流域及各级河流数据:今天给大家分享的数据主要为五个,分别为3级流域、1级河流数据、3级以上河流数据以及4级和5级的河流数据。其中1级河流和3级以上河流数据中存在线状矢量以及面状的湖泊数据;4级和5级的河流数据仅为线状的河流矢量数据。数据中大…

Mysql 8.0主从复制模式安装(兼容Mysql 5.7)

Mysql V8.0.35安装 官网地址:MySQL :: Download MySQL Community Server 下载【Mysql 8.0.35】压缩包 解压压缩包,仅保留6个安装文件即可 mysql-community-client-8.0.31-1.el7.x86_64.rpm mysql-community-client-plugins-8.0.31-1.el7.x86_64.rpm my…

一文带你拿下MySQL之增删查改(基础)

✏️✏️✏️今天给各位带来的是关于数据库增删查改基础方面的知识。 清风的CSDN博客 😛😛😛希望我的文章能对你有所帮助,有不足的地方还请各位看官多多指教,大家一起学习交流! 动动你们发财的小手&#xf…

消息中间件——RabbitMQ(三)理解RabbitMQ核心概念和AMQP协议!

前言 本章学习,我们可以了解到以下知识点: 互联网大厂为什么选择RabbitMQ?RabbiMQ的高性能之道是如何做到的?什么是AMQP高级协议?AMQP核心概念是什么?RabbitMQ整体架构模型是什么样子的?Rabbi…

[译]JavaScript中Base64编码字符串的细节

本文作者为 360 奇舞团前端开发工程师 本文为翻译 原文标题:The nuances of base64 encoding strings in JavaScript 原文作者:Matt Joseph 原文链接:https://web.dev/articles/base64-encoding Base64编码和解码是一种常见的将二进制内容转…

【剪枝】torch-pruning的基本使用

论文:DepGraph: Towards Any Structural Pruning 工程:https://github.com/VainF/Torch-Pruning 算法和库的使用介绍:CVPR 2023 | DepGraph 通用结构化剪枝 1 TP的简介 该算法介绍了DepGraph 如何建模结构化剪枝中的层依赖,实现任…

redis的集群

高可用方案 1、持久化 2、高可用 主从复制 哨兵模式 集群 主从复制: 主从复制是redis实现高可用的基础,哨兵模式和集群都是在主从复制的基础之上实现高可用 主从复制实现数据的多机备份,以及读写分离(主服务器负责写,从服务器…

云HIS系统源码,医院管理系信息统源码,融合B/S版四级电子病历系统

医院管理信息系统是以推进公共卫生、医疗、医保、药品、财务监管信息化建设为着力点,整合资源,加强信息标准化和公共服务信息平台建设,逐步实现统一高效、互联互通的管理系统。 SaaS模式Java版云HIS系统,在公立二甲医院应用三年…

代餐粉产业分析:中国市场销售额增长至116.94亿元

近年来,随着人们生活节奏的加快和健康意识的增强,代餐粉市场规模逐渐壮大。在这个忙碌的时代,快捷、营养而又方便的代餐粉成为了许多人选择的首选。 随着健康理念的不断普及和推广,人们开始更加重视日常饮食的健康与营养。代餐粉作…

Vellum —— 简介

目录 一,介绍 二,原理 三,PBD算法 一,介绍 Vellum是一个解算模拟框架,使用更高级的PBD(XPBD,extended position based dynamics),是2nd Order Integration&#xff08…

Go 实现网络代理

使用 Go 语言开发网络代理服务可以通过以下步骤完成。这里,我们将使用 golang.org/x/net/proxy 包来创建一个简单的 SOCKS5 代理服务作为示例。 步骤 1. 安装 golang.org/x/net/proxy 包 使用以下命令安装 golang.org/x/net 包,该包包含 proxy 子包&am…

2023亿发数字化智能工单,专业管理工单处理全流程,助力企业转型腾飞

伴随着智能化和信息化的不断深入,企业数字化转型势如腾飞。在这个过程中,工单管理成为生产、家电、后勤等多个管理场景下频繁应用的关键环节。如何满足管理方对设备、服务等智能化管理的需求,提升工单管理效率、规范管理流程,并实…

问题:vue2+elementui,tabs切换显示表格并设置表格选中行高亮失败

错误示范: 1.直接setCurrentRow失败(this.currentRow是之前保存的表格当前选中行的数据) this.$refs.table.setCurrentRow(this.currentRow);2.以为是表格没生成就执行了setCurrentRow导致设置不成功,所以使用了this.$nextTick&…

英国国家量子计算中心与IBM签署重要协议!英国进入实用量子时代

​(图片来源:网络) 近日,英国国家量子计算中心(NQCC)与IBM达成了一项重要协议。根据该协议,NQCC将为英国研究人员提供IBM量子高级计划的云访问权限,其中包括IBM的量子计算系统舰队。…

SpringBoot Admin

前言 Spring Boot Admin 是一个管理和监控 Spring Boot 应用程序的开源项目,它提供了一个简洁的 Web 界面来监控 Spring Boot 应用程序的状态和各种运行时指标。Spring Boot Admin 可以帮助开发者快速了解应用程序的状态,并快速定位错误或性能问题。下面…

赛氪荣幸受邀参与中国联合国采购促进会第五次会员代表大会

11 月21 日 (星期二) 下午14:00,在北京市朝阳区定福庄东街1号中国传媒大学,赛氪荣幸参与中国联合国采购促进会第五次会员代表大会。 2022年以来,联合国采购杯全国大学生英语大赛已经走上了国际舞台,共有来自…