(八)Flask之app.route装饰器函数的参数

news/2024/2/21 10:41:20

app.route参数

app.route()是Flask框架中用于定义路由的装饰器函数,它接受一些参数来指定路由的URL规则、请求方法等。

app.route()参数如下:

  1. rule(必选):定义URL规则的字符串,表示要匹配的URL路径。可以包含动态部分,使用尖括号(< >)来指定动态部分的名称和类型。例如:/user/<username>

  2. view_func(必选):用于指定将要执行的视图函数,即处理请求的函数。它接受一个函数作为值。这个函数通常是一个Flask应用程序中定义的视图函数,用于处理路由匹配后的请求。

    例如:

    @app.route('/index')
    def index():return 'Hello, World!'
    

    在这个例子中,view_func就是index函数,它会在匹配到/index路径时被调用。通过将视图函数传递给view_func参数,我们可以将路由和视图函数关联起来,以便在匹配到相应的URL规则时执行相应的视图函数。

  3. methods(可选):定义允许的HTTP请求方法。可以是一个字符串或一个包含多个字符串的列表。默认情况下,允许GET请求。例如:methods=['GET', 'POST']

  4. endpoint(可选):为路由定义一个唯一的端点名称,用于反向生成URL,即: url_for(‘名称’)。如果未指定,默认使用视图函数的名称。例如:endpoint='index'

  5. defaults(可选):为动态部分提供默认值,以便在没有提供相应值时使用。默认值是一个字典。例如:defaults={'page': 1}

    在Flask中,我们可以使用尖括号(< >)来定义动态路由部分,例如<username>。这样的路由规则可以匹配不同的URL路径,其中动态部分的值会作为参数传递给视图函数进行处理。

    然而,有时候在处理请求时可能没有提供相应的动态部分值,或者我们希望在没有提供值时使用一些默认值。这时,就可以使用defaults参数来指定默认值。

    defaults参数接受一个字典作为值,字典的键是动态路由部分的名称,值是对应的默认值。当没有提供对应动态部分的值时,Flask将使用默认值来替代。

    举例:

    @app.route('/user/<username>', defaults={'username': 'GuHanZhe', 'page': 1})
    def user_profile(username, page):return f"Username: {username}, Page: {page}"
    

    在上面的示例中,我们定义了一个路由规则/user/<username>,并为其中的动态路由部分username提供了默认值:GuHanZhe。同时,我们还添加了一个名为page的动态路由部分,并通过defaults参数为其提供了默认值为1。

    当访问/user/johndoe时,username参数将被设置为johndoe,而page参数将使用默认值1。因此,视图函数user_profile将返回"Username: johndoe, Page: 1"

    如果提供了page参数,例如访问/user/johndoe?page=2,则page参数将被设置为2,并覆盖默认值。所以,视图函数将返回"Username: johndoe, Page: 2"

    通过使用defaults参数,我们可以方便地为动态路由部分提供默认值,以应对没有提供相应值的情况。

  6. host(可选):限制路由只匹配特定的主机名。例如:host='example.com'

  7. strict_slashes(可选):控制是否严格匹配URL末尾的斜杠。默认情况下,路由规则对URL末尾的斜杠是不敏感的,即此参数值为False。这意味着/user/user/被视为相同的URL路径,并且可以匹配到同一个路由规则,但可以通过设置为True来禁用这个行为。例如:strict_slashes=True,这样Flask将不会自动处理URL末尾的斜杠。这意味着/user/user/被视为不同的URL路径,需要分别定义对应的路由规则才能匹配到。

  8. subdomain(可选):限制路由只匹配特定的子域名。可以是一个字符串或一个包含多个字符串的列表。例如:subdomain='api'

  9. redirect_to(可选):如果设置为另一个URL,会将请求重定向到该URL。例如:redirect_to='/new-url'

这些参数可以根据需要进行组合使用,以定义具体的路由规则。通过使用这些参数,可以创建出符合需求的路由规则,并将它们与相应的视图函数关联起来。


redirect_to=None,	重定向到指定地址如:@app.route('/index/<int:nid>', redirect_to='/home/<nid>')def func(adapter, nid):return "/home/888"@app.route('/index/<int:nid>', redirect_to=func)subdomain=None,	子域名访问

defaults参数举例:

from flask import Flaskapp = Flask(__name__)@app.route('/index', defaults={'nid': 'xxx'})
def index(nid):print(nid)return 'Index'if __name__ == '__main__':app.run('localhost', 4000)

redirect_to举例:

from flask import Flaskapp = Flask(__name__)@app.route('/index', redirect_to='/new')
def index(nid):print(nid)return '老功能'@app.route('/new')
def new():return '新功能'if __name__ == '__main__':app.run('localhost', 4000)

subdomain举例:

在 Flask 中,路由的 subdomain 参数可以用于匹配 URL 中的子域名,其中子域名是 URL 中域名部分的前缀。例如,blog.example.com 中的子域名是 blog,而父域名是 example.com

下面是使用子域名参数的 Flask 路由示例:

from flask import Flaskapp = Flask(__name__)@app.route('/', subdomain='www')
def index():return 'Welcome to the main site!'@app.route('/', subdomain='blog')
def blog():return 'Welcome to the blog!'if __name__ == '__main__':app.run()

在上面的代码中,我们定义了两个路由函数 index()blog(),它们分别为主域名和子域名设置了路由。其中,subdomain 参数指定了路由函数应该匹配的子域名。

如果我们访问主域名 http://www.example.com/,Flask 会将请求路由到 index() 视图函数,而子域名 http://blog.example.com/ 的请求则会被路由到 blog() 视图函数。

需要注意的是,为了使用子域名参数,我们需要在部署 Flask 应用程序时配置 DNS 服务器或负载均衡器,使其将子域名指向正确的服务器。在本地开发环境中,我们可以在系统的 hosts 文件(windows系统这个文件路径:C:\Windows\System32\drivers\etc)中添加一条域名映射,实现子域名的模拟。

总之,使用 Flask 的 subdomain 参数可以为应用程序添加更加灵活和精细的路由规则,提升应用程序的可用性和用户体验。


http://www.ppmy.cn/news/1191901.html

相关文章

Thinkphp漏洞总结

简介 ThinkPHP是一个免费开源的&#xff0c;快速、简单的面向对象的轻量级PHP开发框架&#xff0c;是为了敏捷WEB应用开发和简化企业应用开发而诞生的。遵循Apache 2开源协议发布&#xff0c;使用面向对象的开发结构和MVC模式&#xff0c;融合了Struts的思想和TagLib&#xff…

前端获取随机数id

function randomId() {return Math.random().toString(16).splice(2, 14); }

嵌入式自学路线大披露!!!

大家有没有想过这2个问题&#xff1a;1. 对于Linux做出来的产品&#xff0c;有些用作监控、有些做手机、有些做平板。那么内核启动后&#xff0c;挂载根文件系统后&#xff0c;应该启动哪一个应用程序呢&#xff1f; 答&#xff1a;内核不知道也不管应该启动哪一个用户程序。…

【精】UML及软件管理工具汇总

目录 1 老七工具&#xff08;规划质量&#xff09; 1.1 因果图&#xff08;鱼骨图、石川图&#xff09; 1.2 控制图 1.3 流程图:也称过程图 1.4 核查表:又称计数表 1.5 直方图 1.6 帕累托图 1.7 散点图&#xf…

C++ Qt 学习(一):Qt 入门

Qt6 安装教程 0. 基础知识 0.1 qmake 和 cmake 对比 qmake&#xff1a;qt 独有的代码构建工具cmake&#xff1a;C 通用的代码构建工具&#xff0c;绝大部分 C 开源项目都使用 cmake 管理代码qt 项目&#xff0c;没有特殊要求&#xff0c;使用 qmake 即可 0.2 Qt 3 个窗口类的…

JVM堆内存解析

一、JVM堆内存介绍 Java大多数对象都是存放在堆中&#xff0c;堆内存是完全自动化管理&#xff0c;根据垃圾回收机制不同&#xff0c;Java堆有不同的结构&#xff0c;下面是我们一台生产环境服务器JVM堆内存空间分配情况&#xff0c;JVM只设置了-Xms2048M -Xmx2048M。 1、JVM堆…

viteePress搭建组件文档

目录 安装vitepress 目录结构 文档首页 Home Page Hero 部分 Features 部分 导航栏配置 logo 导航链接 socialLinks 侧边栏 基本使用 多个侧边栏 使用组件 在 markdown 中导入组件 在 theme 中注册全局组件 部署到Github Pages 前提 第一步 第二步 …

dnf: 错误: conflicts with file from package, mis-match of libstdc++ version

这个错误也是比较的不明确 dnf install libstdc8.5.0-18.el8.i686&#xff0c; 原本机器上安装的64位的libstdc是8.4&#xff0c; 要安装 8.5 的 32位的为什么报这个错误。 Error: Transaction test error: file /usr/share/gcc-8/python/libstdcxx/pycache/init.cpython-36.…

乐分享五五公排,整合资源打造全新消费生态

​小编介绍&#xff1a;10年专注商业模式设计及软件开发&#xff0c;擅长企业生态商业模式&#xff0c;商业零售会员增长裂变模式策划、商业闭环模式设计及方案落地&#xff1b;扶持10余个电商平台做到营收过千万&#xff0c;数百个平台达到百万会员&#xff0c;欢迎咨询。 分…

【免费活动】11月4日敏捷武林上海站 | Scrum.org CEO 亲临现场

活动介绍 过去的几年里&#xff0c;外界的风云变幻为我们的生活增添了一些不一样的色彩。在VUCA世界的浪潮里&#xff0c;每一个人都成为自己生活里的冒险家。面对每一次的变化&#xff0c;勇于探索未知&#xff0c;迎接挑战&#xff0c;努力追逐更好的自己。 七月&#xff0…

系统架构设计热点知识

系统架构设计师考点包括以下内容&#xff1a; 1. 系统设计和架构思想. 了解系统设计和架构的基本概念和思想&#xff0c;特别是面向服务架构&#xff08;SOA&#xff09;、微服务架构、云架构、事件驱动架构、响应式架构等。 系统设计是指在软件项目中&#xff0c;确定系统结…

Kubernetes nginx-ingress组件

运行下面的yaml文件即可 apiVersion: v1 kind: Namespace metadata:name: ingress-nginxlabels:app.kubernetes.io/name: ingress-nginxapp.kubernetes.io/part-of: ingress-nginx---kind: ConfigMap apiVersion: v1 metadata:name: nginx-configurationnamespace: ingress-ng…

微信视频号怎么下载视频,教你一键提取的方法!

今日小众冷门主题来袭&#xff01;居然还有人不知道怎么下载微信视频号的视频&#xff1f;快来跟着我一起学习吧&#xff01; 首先&#xff0c;我们要讨论的是微信视频号。这是一个近年来越来越受欢迎的平台&#xff0c;你可以在上面找到各种有趣的视频内容。但是&#xff0c;…

优优嗨聚集团:医保新政来袭,乙类OTC、保健品或将退出医保舞台,影响几何?

近日&#xff0c;国家医保局发布征求意见稿&#xff0c;拟将乙类OTC&#xff08;非处方药&#xff09;和保健品从医保目录中移除。这一政策一旦实施&#xff0c;无疑将对广大参保人员和相关企业产生深远影响。本文将为您详细解析这一政策可能带来的影响&#xff0c;以及如何应对…

OpenSSL实现SSL网络通信

Certainly! Here are the C language programs for a simple OpenSSL client and server that can establish a secure communication channel between them: l inux环境下 OpenSSL Server Program (server.c): #include <stdio.h> #include <stdlib.h> #include …

创建ABAP数据库表和ABAP字典对象-使用基本类型增加账号字段03

新增字段 现在你将增加字段&#xff1a;account_number,基于基本类型 1.输入以下内容(包括句点)&#xff0c;然后选择“代码补全”(Ctrl空格): key account_number : abap.2.从下拉列表中选择numc(len)并指定len为8。另外&#xff0c;指定这个关键字段为not null: key accoun…

HT3163 免电感滤波 音频功率放大器工作原理

HT3163是一款G效AB/D类音频功率放大器。在D类模式&#xff0c;18V供电、THDN10%条件下&#xff0c;能够持续提供40W/4Ω功率输出。在AB类模式&#xff0c;12V供电、THDN10%条件下&#xff0c;能够持续输出17W/4Ω功率。 HT3163具有防削顶失真&#xff08;ACF&#xff09;输出控…

asr翱捷LORA系列芯片选型参考推荐ASR6601/asr6505/asr6501/asr6500

ASR6601 SoC是国内首颗支持LoRa的LPWAN SoC。ASR6601芯片中集成的超低功耗收发机&#xff0c;除了支持LoRa调制方式外&#xff0c;还可以支持FSK收发、MSK收发和BPSK发射等。在3.3V电源供电的情况下&#xff0c;通过高功率PA&#xff0c;最大可发射22dBM的输出功率。ASR6601与A…

Django实战项目-学习任务系统-自定义URL拦截器

接着上期代码框架&#xff0c;6个主要功能基本实现&#xff0c;剩下的就是细节点的完善优化了。 首先增加URL拦截器&#xff0c;你不会希望没有登录用户就可以进入用户主页各种功能的&#xff0c;所以增加URL拦截器可以解决这个问题。 Django框架本身也有URL拦截器&#xff0…
最新文章