当前位置: 首页 > news >正文

flask中的蓝图

在这里插入图片描述

flask中的蓝图

在 Flask 中,蓝图(Blueprint)是一种组织路由和服务的方法,它允许你在应用中更灵活地组织代码。蓝图可以大致理解为应用或者应用中的一部分,可以在蓝图中定义路由、错误处理程序以及静态文件等。然后可以在工厂函数中多次注册同一个蓝图到应用上,可以用URL前缀和/或子域来区分。

蓝图的主要用途是:

  1. 在一个应用内部划分逻辑组件,例如在一个大的系统中可能会有用户认证、电子邮件、资产等不同的组件,每个组件可以用一个蓝图来实现。
  2. 在一个中大型的项目中,可以用蓝图来做到模块化,每个蓝图都可以在一个独立的模块(Python的模块,即一个.py文件或者一个包)中定义和实现。
  3. 复用性:可以在不同的应用中复用蓝图。

下面是一个简单的蓝图的创建和注册的例子:

# 在你的模块里创建一个蓝图
from flask import Blueprint
bp = Blueprint('my_blueprint', __name__)# 在蓝图上定义路由和其他代码
@bp.route('/')
def index():return 'Hello, Blueprint!'# 在你的应用创建时,注册这个蓝图
from flask import Flask
from yourmodule import bpapp = Flask(__name__)
app.register_blueprint(bp)

在这个例子中,你首先创建了一个蓝图,并在上面定义了一个路由。然后,你在创建 Flask 应用时注册了这个蓝图。

用户登录蓝图

from flask import Blueprint, request, session, redirect, url_for, render_template# 创建一个蓝图
auth = Blueprint('auth', __name__)# 登录视图
@auth.route('/login', methods=['GET', 'POST'])
def login():if request.method == 'POST':username = request.form.get('username')password = request.form.get('password')# 这里为了简单,我们假设用户名是'user',密码是'password'# 实际上,你需要去数据库中验证用户名和密码if username == 'user' and password == 'password':session['username'] = usernamereturn redirect(url_for('index'))else:return 'Invalid username or password'else:return render_template('login.html')# 登出视图
@auth.route('/logout')
def logout():if 'username' in session:session.pop('username')return redirect(url_for('index'))

这个蓝图可以在你的应用中使用register_blueprint函数进行注册:

from flask import Flask
from your_module import auth  # 从你的模块导入蓝图app = Flask(__name__)
app.register_blueprint(auth, url_prefix='/auth')

其中,your_module 需要替换为你的蓝图定义的模块名。url_prefix='/auth'意味着所有注册的路由都会添加一个前缀/auth,所以你的登录和登出URL将分别变为/auth/login/auth/logout

复用蓝图

你只需要将蓝图定义在一个模块中,然后在需要的地方导入并注册这个蓝图就可以了。

举个例子,假设我们已经在auth_module.py模块中定义了上面的auth蓝图:

# auth_module.py
from flask import Blueprint, request, session, redirect, url_for, render_templateauth = Blueprint('auth', __name__)@auth.route('/login', methods=['GET', 'POST'])
def login():# ...@auth.route('/logout')
def logout():# ...

然后,你可以在你的多个Flask应用中导入并注册这个蓝图:

# app1.py
from flask import Flask
from auth_module import authapp1 = Flask(__name__)
app1.register_blueprint(auth, url_prefix='/auth')# app2.py
from flask import Flask
from auth_module import authapp2 = Flask(__name__)
app2.register_blueprint(auth, url_prefix='/auth')

在这个例子中,auth蓝图被复用在了两个不同的Flask应用中。在每个应用中,所有的路由都会添加一个/auth的前缀。

所以,要复用一个蓝图,你只需要将蓝图定义在一个模块中,然后在需要的地方导入并注册这个蓝图就可以了。

蓝图路由

当我们在蓝图中定义路由时,生成这些路由的URL需要使用蓝图的名字作为前缀。这样可以避免不同蓝图中的视图函数名发生冲突。以下是一个例子:

首先,我们定义两个蓝图,分别为authmain

# auth.py
from flask import Blueprint, redirect, url_forauth = Blueprint('auth', __name__)@auth.route('/login')
def login():return "Login Page"
# main.py
from flask import Blueprint, redirect, url_formain = Blueprint('main', __name__)@main.route('/')
def index():return redirect(url_for('auth.login'))  # 重定向到auth蓝图的login视图

然后,在主程序中注册这两个蓝图:

# app.py
from flask import Flask
from auth import auth
from main import mainapp = Flask(__name__)
app.register_blueprint(auth, url_prefix='/auth')
app.register_blueprint(main)

在这个例子中,我们在main蓝图的index视图中生成了一个URL,这个URL指向auth蓝图的login视图。生成这个URL的代码是url_for('auth.login'),其中,auth是蓝图的名字,login是视图函数的名字。这行代码会生成一个/auth/login的URL。

注意,url_for函数生成的URL是相对于应用根URL的。如果你在注册蓝图时添加了一个URL前缀,这个前缀也会被添加到生成的URL中。例如,在上面的例子中,我们在注册auth蓝图时添加了一个/auth的前缀,所以url_for('auth.login')生成的URL是/auth/login

在Flask中,url_for函数用于生成URL。在其最简单的形式中,你可以传递一个视图函数的名字,然后它会返回对应的URL。例如,如果你有一个名为login的视图函数,你可以使用url_for('login')来生成对应的URL。

然而,当你开始使用蓝图时,情况就会变得有些复杂。这是因为你可能会在不同的蓝图中使用相同的视图函数名。为了避免冲突,Flask在内部为每个蓝图中的视图函数添加了一个前缀,这个前缀就是蓝图的名字。所以,如果你在auth蓝图中有一个名为login的视图函数,你需要使用url_for('auth.login')来生成对应的URL。

实际上,'auth.login'只是一个字符串,Flask会在内部将它解析为蓝图的名字和视图函数的名字。

所以,当你在使用url_for函数时,你需要记住:

  • 如果你在主应用中(也就是没有使用蓝图的情况下),你可以直接使用视图函数的名字,例如url_for('login')
  • 如果你在蓝图中,你需要在视图函数的名字前添加蓝图的名字和一个点,例如url_for('auth.login')

相关文章:

flask中的蓝图

flask中的蓝图 在 Flask 中,蓝图(Blueprint)是一种组织路由和服务的方法,它允许你在应用中更灵活地组织代码。蓝图可以大致理解为应用或者应用中的一部分,可以在蓝图中定义路由、错误处理程序以及静态文件等。然后可以…...

Spring Cloud+Spring Boot+Mybatis+uniapp+前后端分离实现知识付费平台免费搭建

Java版知识付费-轻松拥有知识付费平台 多种直播形式,全面满足直播场景需求 公开课、小班课、独立直播间等类型,满足讲师个性化直播场景需求;低延迟、双向视频,亲密互动,无论是互动、答疑,还是打赏、带货、…...

uniapp 瀑布流 (APP+H5+微信小程序)

WaterfallsFlow.vue <template><view class"wf-page" :class"props?.paddingC ? paddingC : "><!-- left --><view><view id"left" ref"left" v-if"leftList.length"><viewv-for…...

医疗小程序:提升服务质量与效率的智能平台

在医疗行业&#xff0c;公司小程序成为提高服务质量、优化管理流程的重要工具。通过医疗小程序&#xff0c;可以方便医疗机构进行信息传播、企业展示等作用&#xff0c;医疗机构也可以医疗小程序提供更便捷的预约服务&#xff0c;优化患者体验。 医疗小程序的好处 提升服务质量…...

ComPDFKit 转档SDK OCR表格识别功能

我们非常高兴地宣布&#xff0c;适用于 Windows、iOS、Android 和服务器的 ComPDFKit 转档SDK 1.8.0 现已发布&#xff01;在该版本中&#xff0c;OCR 功能支持了表格识别&#xff0c;优化了OCR文字识别率。PDF to HTML 优化了html 文件结构&#xff0c;使转换后的 HTML 文件容…...

华为OD机考--阿里巴巴黄金箱

题目内容 贫如洗的樵夫阿里巴巴在去砍柴的路上&#xff0c;无意中发现了强盗集团的藏宝地&#xff0c;藏宝地有编号从0~N的箱子每个箱子上面贴有一个数字箱子中可能有一个黄金宝箱。 黄金宝箱满足排在它之前的所有箱子数字和等于排在它之后的所有箱子数字之和; 一个箱子左边部分…...

mybatis-config.xml-配置文件详解

文章目录 mybatis-config.xml-配置文件详解说明文档地址:配置文件属性解析properties 属性应用实例 settings 全局参数定义应用实例 typeAliases 别名处理器举例说明 typeHandlers 类型处理器environments 环境environment 属性应用实例 mappers配置 mybatis-config.xml-配置文…...

【雕爷学编程】MicroPython动手做(18)——掌控板之声光传感器

知识点&#xff1a;什么是掌控板&#xff1f; 掌控板是一块普及STEAM创客教育、人工智能教育、机器人编程教育的开源智能硬件。它集成ESP-32高性能双核芯片&#xff0c;支持WiFi和蓝牙双模通信&#xff0c;可作为物联网节点&#xff0c;实现物联网应用。同时掌控板上集成了OLED…...

Ribbon源码

学了feign源码之后感觉&#xff0c;这部分还是按运行流程分块学合适。核心组件什么的&#xff0c;当专业术语学妥了。序章&#xff1a;认识真正のRibbon 但只用认识一点点 之前我们学习Ribbon的简单使用时&#xff0c;都是集成了Eureka-client或者Feign等组件&#xff0c;甚至在…...

Linux下在终端输入密码隐藏方法

Linux系统中&#xff0c;如何将在终端输入密码时将密码隐藏&#xff1f; 最近做简单的登录界面时&#xff0c;不做任何操作的话&#xff0c;在终端输入密码的同时也会显示输入的密码是什么&#xff0c;这样对于隐蔽性和使用都有不好的体验。那么我就想到将密码用字符*隐藏起来…...

【ARM 常见汇编指令学习 3 -- ARM64 无符号位域提取指令 UBFX】

文章目录 ARM64 无符号位域提取指令 上篇文章&#xff1a;ARM 常见汇编指令学习 2 – 存储指令 STP 与 LDP 下篇文章&#xff1a;ARM 常见汇编指令学习 4 – ARM64 比较指令 cbnz 与 b.ne 区别 ARM64 无符号位域提取指令 在代码中如何监控寄存器的某1bit&#xff0c; 或者某几…...

求分享如何批量压缩视频的容量的方法

视频内存过大&#xff0c;不但特别占内存&#xff0c;而且还会使手机电脑出现卡顿的现象&#xff0c;除此之外&#xff0c;如果我们想发送这些视频文件可能还会因为内存太大无法发送。因此&#xff0c;我们可以批量地压缩视频文件的内存大小&#xff0c;今天小编要来分享一招&a…...

ChatGPT 是如何工作的:从预训练到 RLHF

欢迎来到人工智能的未来&#xff1a;生成式人工智能&#xff01;您是否想知道机器如何学习理解人类语言并做出相应的反应&#xff1f;让我们来看看ChatGPT ——OpenAI 开发的革命性语言模型。凭借其突破性的 GPT-3.5 架构&#xff0c;ChatGPT 席卷了世界&#xff0c;改变了我们…...

KafKa脚本操作

所有操作位于/usr/local/kafka_2.12-3.5.1/bin。 rootubuntu2203:/usr/local/kafka_2.12-3.5.1/bin# pwd /usr/local/kafka_2.12-3.5.1/bin rootubuntu2203:/usr/local/kafka_2.12-3.5.1/bin# ls connect-distributed.sh kafka-delegation-tokens.sh kafka-mirror-mak…...

【自动化运维】playbook剧本

目录 一、Ansible 的脚本 playbook 剧本1.1playbooks的组成 二、剧本编写实验2.1定义、引用变量2.2使用远程主机sudo切换用户2.3whenn条件判断2.4迭代 三、Templates 模板四、Tags模板 一、Ansible 的脚本 playbook 剧本 1.1playbooks的组成 &#xff08;1&#xff09;Tasks&…...

java中双引号和单引号的区别

起因 刷题的时候&#xff0c;有判断是否相同的情况&#xff0c;然后我发现单引号和双引号在上的表现不一样&#xff0c;所以记录一下。 解释 在Java中&#xff0c;双引号&#xff08;" "&#xff09;和单引号&#xff08;’ &#xff09;在使用上有很重要的区别&a…...

jenkinsfile指定jenkins流水线的构建号

背景 升级Jenkins过程中不小心导致流水线配置文件job目录丢失, 重新配置流水线后所有流水线构建号码都从1开始构建了, 然而我们的产品关联了jenkins构建号,重新从1 构建会导致各种问题. 解决方案 在Jenkinsfile文件中指定流水线的构建号为一个不存在的数字, 这样就不会冲突了…...

微信小程序:实现提示窗确定,取消执行不同操作(消息提示确认取消)showModal

效果 代码 wx.showModal({title: 提示,content: 是否确认退出,success: function (res) {if (res.confirm) {console.log(用户点击确定)} else if (res.cancel) {console.log(用户点击取消)}}})...

深度学习论文: Q-YOLO: Efficient Inference for Real-time Object Detection及其PyTorch实现

深度学习论文: Q-YOLO: Efficient Inference for Real-time Object Detection及其PyTorch实现 Q-YOLO: Efficient Inference for Real-time Object Detection PDF: https://arxiv.org/pdf/2307.04816.pdf PyTorch代码: https://github.com/shanglianlm0525/CvPytorch PyTorch代…...

解读随机森林的决策树:揭示模型背后的奥秘

一、引言 随机森林[1]是一种强大的机器学习算法&#xff0c;在许多领域都取得了显著的成功。它由多个决策树组成&#xff0c;而决策树则是构建随机森林的基本组件之一。通过深入解析决策树&#xff0c;我们可以更好地理解随机森林模型的工作原理和内在机制。 决策树是一种树状结…...

React第五十七节 Router中RouterProvider使用详解及注意事项

前言 在 React Router v6.4 中&#xff0c;RouterProvider 是一个核心组件&#xff0c;用于提供基于数据路由&#xff08;data routers&#xff09;的新型路由方案。 它替代了传统的 <BrowserRouter>&#xff0c;支持更强大的数据加载和操作功能&#xff08;如 loader 和…...

Linux-07 ubuntu 的 chrome 启动不了

文章目录 问题原因解决步骤一、卸载旧版chrome二、重新安装chorme三、启动不了&#xff0c;报错如下四、启动不了&#xff0c;解决如下 总结 问题原因 在应用中可以看到chrome&#xff0c;但是打不开(说明&#xff1a;原来的ubuntu系统出问题了&#xff0c;这个是备用的硬盘&a…...

20个超级好用的 CSS 动画库

分享 20 个最佳 CSS 动画库。 它们中的大多数将生成纯 CSS 代码&#xff0c;而不需要任何外部库。 1.Animate.css 一个开箱即用型的跨浏览器动画库&#xff0c;可供你在项目中使用。 2.Magic Animations CSS3 一组简单的动画&#xff0c;可以包含在你的网页或应用项目中。 3.An…...

掌握 HTTP 请求:理解 cURL GET 语法

cURL 是一个强大的命令行工具&#xff0c;用于发送 HTTP 请求和与 Web 服务器交互。在 Web 开发和测试中&#xff0c;cURL 经常用于发送 GET 请求来获取服务器资源。本文将详细介绍 cURL GET 请求的语法和使用方法。 一、cURL 基本概念 cURL 是 "Client URL" 的缩写…...

9-Oracle 23 ai Vector Search 特性 知识准备

很多小伙伴是不是参加了 免费认证课程&#xff08;限时至2025/5/15&#xff09; Oracle AI Vector Search 1Z0-184-25考试&#xff0c;都顺利拿到certified了没。 各行各业的AI 大模型的到来&#xff0c;传统的数据库中的SQL还能不能打&#xff0c;结构化和非结构的话数据如何和…...

基于鸿蒙(HarmonyOS5)的打车小程序

1. 开发环境准备 安装DevEco Studio (鸿蒙官方IDE)配置HarmonyOS SDK申请开发者账号和必要的API密钥 2. 项目结构设计 ├── entry │ ├── src │ │ ├── main │ │ │ ├── ets │ │ │ │ ├── pages │ │ │ │ │ ├── H…...

【免费数据】2005-2019年我国272个地级市的旅游竞争力多指标数据(33个指标)

旅游业是一个城市的重要产业构成。旅游竞争力是一个城市竞争力的重要构成部分。一个城市的旅游竞争力反映了其在旅游市场竞争中的比较优势。 今日我们分享的是2005-2019年我国272个地级市的旅游竞争力多指标数据&#xff01;该数据集源自2025年4月发表于《地理学报》的论文成果…...

基于谷歌ADK的 智能产品推荐系统(2): 模块功能详解

在我的上一篇博客&#xff1a;基于谷歌ADK的 智能产品推荐系统(1): 功能简介-CSDN博客 中我们介绍了个性化购物 Agent 项目&#xff0c;该项目展示了一个强大的框架&#xff0c;旨在模拟和实现在线购物环境中的智能导购。它不仅仅是一个简单的聊天机器人&#xff0c;更是一个集…...

[QMT量化交易小白入门]-六十二、ETF轮动中简单的评分算法如何获取历史年化收益32.7%

本专栏主要是介绍QMT的基础用法,常见函数,写策略的方法,也会分享一些量化交易的思路,大概会写100篇左右。 QMT的相关资料较少,在使用过程中不断的摸索,遇到了一些问题,记录下来和大家一起沟通,共同进步。 文章目录 相关阅读1. 策略概述2. 趋势评分模块3 代码解析4 木头…...

Vuex:Vue.js 应用程序的状态管理模式

什么是Vuex&#xff1f; Vuex 是专门为 Vue.js 应用程序开发的状态管理模式 库。它采用集中式存储管理应用的所有组件的状态&#xff0c;并以相应的规则保证状态以一种可预测的方式发生变化。 在大型单页应用中&#xff0c;当多个组件共享状态时&#xff0c;简单的单向数据流…...