Flask—路由

本文详细探讨了Flask框架中的路由配置,包括添加路由的方式、路由参数的使用,以及动态路由参数的实现。通过路由装饰器,开发者可以灵活地定义URL到特定视图函数的映射,实现强大的Web应用功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、添加路由方式

# 方式一
@app.route("/index", endpoint='index')
def my_flask():
    time.sleep(1)
    
    return "hello world"

# 方式二
def my_flask():
    time.sleep(1)
    
    return "hello world"

app.add_url_rule("/index", view_func=my_flask)

二、路由配置

1. 路由参数

app.add_url_rule("路由地址", view_func=视图函数, endpoint="反向地址")

2. 路由装饰器中的参数

# @app.route(),此装饰器中的参数

1. methods:当前url地址允许访问的请求方式
    @app.route("/info", methods=["GET","POST"])

2. endpoint:反向url地址,默认为视图函数名(url_for)

    (1)实例
    from flask import url_for

    @app.route("/info", methods=["GET","POST"], endpoint='r_info')
    def student_info():
        # 用url_for根据视图函数名找url路径,需导入
        print(url_for("r_info")) # /info
        stu_id = int(request.args['id'])

        # Python3.6的新特性 f"{变量名}"
        return f"{stu_id}" 

3. defaults:视图函数的参数默认值{'nid':1}

    (1) 实例
    from flask import url_for

    @app.route("/info",endpoint="r_info", defaults={"nid": 100})
    def student_info(nid):
        print(url_for("r_info"))  # /info
        # stu_id = int(request.args["id"])
        print(nid)  # 100

        # Python3.6的新特性 f"{变量名}"
        return f" {nid}"  

4. strict_slashes:url地址结尾符"/"的控制 False : 无论结尾 "/" 是否存在均可以访问 , True : 结尾必须不能是 "/"

    (1) 实例
    # 访问地址 : /info
    @app.route("/info", strict_slashes=True)
    def student_info():
        return "hello world"
    
    # 访问地址 : /infos  or  /infos/
    @app.route("/infos", strict_slashes=False)
    def student_infos():
        return "hello world"

5. redirect_to : url地址永久重定向(301)

    (1) 实例
    # 访问地址 : /info 浏览器跳转至 /infos
    @app.route("/info", strict_slashes=True, redirect_to="/infos")
    def student_info():
        return "hello world"
    
    @app.route("/infos", strict_slashes=False)
    def student_infos():
        return "hello world"

6. subdomain : 子域名前缀
    
    subdomian="DragonFire" 这样写可以得到子域名.主域名前提是
    app.config["SERVER_NAME"] = "as.com"

    (1) 实例
    app.config["SERVER_NAME"] = "as.com"
    @app.route("/info",subdomain="son")
    def student_info():
        return "hello world"
    # 访问地址为:  son.as.com/info


3. 动态路由参数

from flask import url_for

# 访问地址: http://127.0.0.1:5000/info/1
@app.route("/info/<int:nid>", methods=["GET","POST"], endpoint="r_info")
def student_info(nid):
    print(url_for("r_info", nid=2)) # /info/2
    
    return f"{nid}"

备注:
    <int:nid>就是在url后定义的一个参数接收,但是这种动态参数路由,在url_for的时候,
    一定要将动态参数名+参数值添加进去,否则会抛出参数错误的异常
      

 

### Python Flask 框架路由使用教程 #### 创建Flask应用对象 为了开始构建基于Flask的应用程序,首先要创建一个`Flask`类的对象。这可以通过传递模块名给构造函数完成,通常是通过双下划线属性`__name__`实现。 ```python from flask import Flask app = Flask(__name__) ``` 此操作初始化了一个名为`app`的Flask应用程序实例[^2]。 #### 定义基本路由Flask中,路由负责将特定URL模式与视图函数关联起来。最简单的方式是利用装饰器`@app.route()`来指定路径以及对应的处理逻辑: ```python @app.route('/') def index(): return 'Hello, Flask!' ``` 上述代码片段设置了一条根目录(`/`)到`index`函数间的映射关系;当访问网站主页时会返回字符串'Hello, Flask!'作为响应内容。 #### 添加带有变量的动态路由 除了静态页面外,还可以设计更灵活多变的链接结构——即支持参数化的URI模板。这些参数可以在请求到达服务器端之后被提取出来并传入目标方法内部供进一步处理。常见的几种可选数据类型包括但不限于整数(int),浮点数(float),通用字符序列(string)等。 ```python @app.route('/user/<string:username>') def show_user_profile(username): # 显示用户名为 username 的用户资料页 return f'User {username}' @app.route('/post/<int:post_id>') def show_post(post_id): # 展示编号为 post_id 的文章详情 return f'Post {post_id}' ``` 这里定义了两个新的路由规则:一个是接收任意长度字母组成的用户名部分(`/user/<string:username>`), 另一个则是仅限于正整数值的文章ID字段(`/post/<int:post_id>`)。每当有匹配该形式的HTTP GET请求到来之时,相应的方法就会被执行并将捕获到的实际值当作实参传递进去[^1]。 #### 处理多种HTTP请求方式 默认情况下,所有的路由都只监听GET类型的网络通信动作。然而,在实际开发过程中往往还需要考虑到POST、PUT或者其他标准协议里所规定的交互手段。为此,只需向装饰符内追加额外的关键字参数即可满足需求: ```python @app.route('/login', methods=['GET', 'POST']) def login(): if request.method == 'POST': return do_the_login() else: return show_the_login_form() def do_the_login(): pass # 实现登录业务逻辑 def show_the_login_form(): pass # 渲染显示登录表单界面 ``` 这段示范展示了如何区分对待不同种类的消息发送行为,并据此采取不同的应对措施。特别是对于那些涉及敏感信息交换的操作而言(比如身份验证),确保采用恰当的安全机制至关重要。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值