FLASK博客系列4——再谈路由

news2024/12/25 0:15:40

        最近好像拖更有点久了。抱歉抱歉~

        

        今天我们继续来聊聊路由(其实就是我上次偷懒剩下一点没讲完)。

       通过上次的文章,我们基本了解了Flask中的路由,是不是比较简单呢?别急,今天来点猛料。

       一、路由之HTTP方法绑定。

            我们都知道网站通过HTTP与浏览器或其他客户端进行交互,而访问一个URL时通常有好几种访问方式。像我们用浏览器平时访问百度啊,用的其实是Get。像其他的方法还有POST、HEAD、PUT、DELETE等,详细的大家可以自行百度。

               在Flask中,路由默认设置使用GET方式进行路径访问。

         1、指定HTTP访问方式的方法。

                有小伙伴就说了,那我想改变访问的方式怎么办?

                其实很简单,我们只需要修改route()中的参数,就可以配置其他访问方式。举个栗子:

@app.route('/', methods=['GET', 'POST'])
def hello_world():
    return 'Hello World!'

               然后我们这次用大家都比较熟悉的神器postman来调用一下我们的接口。我们选择POST方法访问,可以看到我们成功访问了。如下图:

              

            如果不设置允许POST方法,那么flask就会返回405,如下图:

            

               那就算客户端用了不同的方式访问,我们怎么知道是哪一种呢?诶,调皮,Flask早就为我们考虑到了。我们可以通过request.method来获取客户端的请求方式。request是Flask框架的一个全局对象,可以获得很多和HTTP请求的客户端相关的信息,比如cookies、headers、data、file等等。示例代码如下:

@app.route('/', methods=['GET', 'POST'])
def hello_world():
    if request.method == "GET":
        return "GET方法"
    else:
        return 'Hello World!'

            当使用GET方法访问的时候,就会返回“GET方法”,而用POST就会返回“Hello World!

            对了,顺带说一句,设置允许请求方法的时候,名字是可以大小写混用的,你可以写成“get”或者“Get”,当然一般还是统一一下比较好。悄悄告诉你,这是因为Flask最终都会将你写的转为大写,所以不影响。可见人家早就预料到你们会搞这些花里胡哨的东西了。源码如下:

methods = set(item.upper() for item in methods)

            

        2、同一个URL映射到不同的函数

       有些小伙伴说我不想用request.method去判断,我想要花里胡哨。好,行行行,依你依你~

        我们来看一段代码:

@app.route('/hello', methods=['GET'])
def hello():
    return '花里胡哨的GET'

@app.route('/hello', methods=['POST'])
def hi():
    return '花里胡哨的POST'

         再看看访问的结果:

        

        好啦。这就是你们要的花里胡哨的效果。之所以可以这样做(还不是人家早知道你们整天就喜欢搞这些花里胡哨的东西),实际上是Flask定义了2组隐式的访问方式的规则。

        二、路由地址反向生成

            通过签名花里胡哨的操作,不不不,是学习,相信你已经掌握了更多关于路由的功能。到这里,有些同学又要来搞一波操作了。既然能通过路由去访问到函数,那可不可以通过函数来知道路由地址呢?这个问题就很有水平了。答案当然是可以啦,我们一起来看看。

            这次不卖关子了,我们先从Flask包中引入url_for函数。

from flask import url_for

            接着看一则完整的例子:

from flask import Flask
from flask import url_for

app = Flask(__name__)


@app.route('/')
def hello_world():
    # 返回hello函数所对应的URL
    return url_for("hello")


@app.route('/hello')
def hello():
    return 'hello world!'


if __name__ == '__main__':
    app.run()

            接着我们去访问 http://127.0.0.1:5000 。可以看到,hello函数对应的URL就显示出来了。

            

            url_for函数的第1个参数是需要获取URL的函数名,如果URL有变量,只需要在函数中添加参数然后对其赋值即可。我们再看一个例子:

            

from flask import Flask
from flask import url_for

app = Flask(__name__)


@app.route('/')
def hello_world():
    print(url_for('hello'))  # /hello
    print(url_for('hello', name="clannadhh"))  # /hello?name=clannadhh
    print(url_for('hi', name="clannadhh"))  # /hi/clannadhh
    return "http://www.clannadhh.club"


@app.route('/hello')
def hello():
    return 'hello world!'


@app.route('/hi/<string:name>')
def hi(name):
    return 'hello %s' % name


if __name__ == '__main__':
    app.run()

            使用url_for函数有什么好处呢?

  •     反向解析比硬编码有更好的可读性和可维护性。比如,当需要更换路由函数中的URL的地址时,你的代码改动就会非常小。
  •     url_for函数还会自动处理特殊字符,同时也会做Unicode编码转换。像空格就会转换成“%20”,而中文同样的也会转换,因为flask是不知道中文的。

            最后教大家个花里胡哨的东西,至于效果怎样,那就等待大家试了之后留言吧。记得打赏,疯狂暗示~

@app.route('/rmb')
@app.route('/nb')
@app.route('/')
def hello_world():
    return "hello world!"

            现在再去访问以下3个地址,看会发生什么?

http://127.0.0.1:5000/
http://127.0.0.1:5000/nb
http://127.0.0.1:5000/rmb

          好啦,今天内容还是蛮多的。好看记得推荐给身边的朋友吧,打个赏再走呗~

          

  

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

在CentOS系统下的Tomcat8.5或9安装SSL证书

您可以在CentOS系统下的Tomcat服务器安装SSL证书&#xff0c;实现通过HTTPS安全访问Web服务。本文介绍如何CentOS系统下Tomcat 8.5或9安装SSL证书。 环境准备 操作系统&#xff1a;CentOS 7.6 64位 Web服务器&#xff1a;Tomcat 8.5或9 说明 Tomcat服务器需要提前安装JDK环…

C++基础 -25- 动态多态

静态多态在程序编译的时候&#xff0c;确定将要执行的状态。 动态多态在程序运行的时候&#xff0c;才能确定执行的状态。 下面举例实现动态多态 work函数接口通过传参不同做不同的工作 #include "iostream"using namespace std;class person {public:person(){}vi…

10个让UI设计更轻松的工具

UI设计软件对设计师来说非常重要。UI设计工具的使用是否直接影响到最终结果的质量&#xff0c;然后有人会问&#xff1a;UI界面设计使用什么软件&#xff1f;这里有一些UI设计师和那些对UI设计感兴趣的朋友列出了10个易于使用和免费的UI设计软件。 即时设计 即时设计是一款免…

《曾国藩传》:崇尚笨拙的人生哲学

哈喽啊&#xff0c;大家好&#xff0c;我是雷工&#xff01; 以前读书喜欢读小说&#xff0c;喜欢看《我从你的全世界路过》《云间有个小卖铺》这些轻松的小说&#xff0c;读起来很轻松。 随着年龄增长&#xff0c;阅历的增加开始喜欢读历史&#xff0c;读人物传记&#xff0c;…

【涂鸦T2-U】2、添加光感bh1750

文章目录 前言一、基础介绍二、电路图2.1 电路图12.2 电路图2——实际采用 三、代码四、编译五、刷机六、测试结果小结 前言 本章介绍如何在涂鸦T2-U开发板上添加光感bh1750驱动并实现定时读取数据。 一、基础介绍 BH1750( GY-302 )光照传感器 这篇文章有bh1750的基础介绍。…

关于 ls -s 输出文件大小的单位问题的讨论

自己看书正好看到这里&#xff0c;正纳闷呢&#xff0c;上网查了下&#xff0c;发现不是我自己在为这个问题感到困惑。 有个大哥提出一个问题&#xff1a; 问题标题&#xff1a; ls -s的单位到底是什么&#xff1f; man ls -s, --size print the alloca…

库位角点检测之Centernet/CornerNet算法

1.CornerNet CornerNet 那么我们从bounding box左上角(top-left corner)看物体。视线横着的话&#xff0c;物体就在视线的下面&#xff08;那么视线所在位置为the topmost boundary of an object&#xff09;。视线竖着的话&#xff0c;物体就在视线的右边&#xff0c;那么视线…

CCFCSP试题编号:202009-2试题名称:风险人群筛查

#include <iostream> using namespace std;//判断是否在区域 bool isIn(int xl, int yd, int xr, int yu, int x, int y) {if ((x > xl && x < xr) && (y > yd && y < yu)){return true;}return false; }struct position {int a, b;…

【linux】日志有哪些

Linux系统日志主要有以下几种类型&#xff1a; 内核及系统日志&#xff1a;这种日志数据由系统服务rsyslog统一管理&#xff0c;根据其主配置文件/etc/rsyslog.conf中设置决定内核消息及各种系统程序消息记录到什么位置。/var/log/message&#xff1a;该日志文件存放了内核消息…

RDD2022提交官网得到F1-Score的步骤【自己摸索的,不保证对和全面,返回结果是F1-Score: India=nan】

文章目录 提交地址RDD2022提交的步骤1. 进入到官网2. 注册账号&登陆账号3. 提交界面4. 代码&#xff0c;制作符合要求的txt5. 提交后返回的结果 提交地址 RDD2022提交地址&#xff1a;https://crddc2022.sekilab.global/submissions/ RDD2020提交地址&#xff1a;https://…

nnDetection简明安装和训练流程(Windows环境)

安装 首先&#xff0c;官方不建议Windows安装&#xff0c;推荐Linux Docker 我的环境&#xff1a; ● 操作系统平台&#xff1a; Windows 10 ● Python&#xff1a; 3.8 ● Torch/TorchVision&#xff1a; 1.10.1cu102/ 0.11.1 ● GPU&#xff1a; Nvidia RTX 2080 Ti 11G…

【BEV感知 LSS方案】Lift-Splat-Shoot(LSS)

前言 LSS全称是Lift-Splat-Shoot&#xff0c;它先从车辆周围的多个摄像头拍摄到的图像进行特征提取&#xff0c;在特征图中估计出每个点的深度&#xff0c;然后把这些点“提升”到3D空间中。 接着&#xff0c;这些3D信息被放置到一个网格上&#xff0c;最后将这些信息“拍扁”…

转向更卷的奶茶 库迪这是要在咖啡上认怂?

卖咖啡刚满一年&#xff0c;陆正耀就带着名为“茶猫”的奶茶项目再度登场。 根据多位网友的爆料&#xff0c;茶猫采取和库迪咖啡一样的联营商模式&#xff0c;且有低价补贴策略&#xff0c;主打低价茶饮市场&#xff0c;全场统一定价6.9元。 熟悉的加盟模式&#xff0c;熟悉的…

国际上有哪些比较出名的VOIP供应商

1. Skype&#xff08;微软&#xff09;&#xff1a;企业发展历程&#xff1a;Skype 于2003年成立&#xff0c;最初由瑞典和丹麦的几位开发者创建。2005年被eBay收购&#xff0c;之后于2011年被微软收购。微软将 Skype 合并到其产品生态系统&#xff0c;并继续开发和改进该平…

性能测试JVM优化实战

&#xff08;1&#xff09;、实现高并发需要考虑的问题&#xff1a;12 条金字规则 实现高并发需要考虑&#xff1a; &#xff08;1&#xff09;系统的架构设计&#xff0c;如何在架构层面减少不必要的处理&#xff08;网络请求&#xff0c;数据库操作等&#xff09;--- 亿级流…

推荐一款优秀的json在线格式化校验工具

www.bjson.chat 这个工具是目前见过最好用的JSON工具&#xff0c; 页面简单&#xff0c;支持text&#xff0c;tree两种显示格式&#xff0c;关键词高亮显示支持亮白和暗黑两种风格最主要的是如果要格式化很长的json的话&#xff0c;这个工具还可以全屏显示&#xff0c;简直不…

真空环境试验箱中的精密低气压控制解决方案

摘要&#xff1a;针对用户提出的低气压试验箱中的真空度精密可编程控制&#xff0c;以及0.001~1000Torr的宽域真空度控制范围&#xff0c;本文基于动态平衡法提出了切实可行的解决方案。解决方案采用了上游控制和下游控制两路独立高精度的PID程序控制回路&#xff0c;基于不同量…

Python 批量修改文件名

主要步骤 通过os.listdir查看该文件夹下所有的文件&#xff08;包括文件夹&#xff09;遍历所有文件&#xff0c;如果是文件夹则跳过&#xff0c;或指定跳过指定文件获取文件扩展名按照需求生成新的文件路径文件名进行重命名 代码示例 # -*- coding: utf-8 -*- import osdef…

Python知识碎片补充【侯小啾python领航班系列(十四)】

Python知识碎片补充【侯小啾python领航班系列(十四)】 大家好,我是博主侯小啾, 🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ�…

Adobe ColdFusion文件读取漏洞(CVE-2010-2861)

任务一&#xff1a; 复现漏洞 任务二&#xff1a; 尝试利用漏洞读取目标系统中的“opt/coldfusion8/license.txt"文件 1.环境搭建&#xff08;网上写的密码是admin&#xff0c;就用admin&#xff09; 2.看答案就是一层一层进行路径穿越攻击&#xff0c;这里要注意如果…