Flask之路由(app.route)详解

目录

创建路由的两种方式

方式一

方式二

 反向生成URL

 注意事项 !!!

原因 :

解决 :

总结 :

自定义路由转换器

重定向


在讲创建路由之前先了解大致流程,工作本质

在 route 源码中

    def route(self, rule: str, **options: t.Any) -> t.Callable:
        """Decorate a view function to register it with the given URL
        rule and options. Calls :meth:`add_url_rule`, which has more
        details about the implementation.

        .. code-block:: python

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

        See :ref:`url-route-registrations`.

        The endpoint name for the route defaults to the name of the view
        function if the ``endpoint`` parameter isn't passed.

        The ``methods`` parameter defaults to ``["GET"]``. ``HEAD`` and
        ``OPTIONS`` are added automatically.

        :param rule: The URL rule string.
        :param options: Extra options passed to the
            :class:`~werkzeug.routing.Rule` object.
        """

        def decorator(f: t.Callable) -> t.Callable:
            endpoint = options.pop("endpoint", None)
            self.add_url_rule(rule, endpoint, f, **options)
            return f

        return decorator

这一部分

 解释一下就是

程序从上往下 首先进入app.route路由部分然后 执行了 decorator

这里的 def decorator()  就相当于将 app.route赋给 decorator

        decorator = app.route('/index',methods=['GET','POST'])

 @decorator

- decoratoe ( 函数名 )

创建路由的两种方式

方式一

别忘了 导包创建一个实例

from flask import Flask

app = Flask(__name__)
@app.route('/one',methods=['GET','POST'])
def one():
    return "创建路由的方法一,返回值为: one"

 运行 :

方式二

使用 add_url_rule  

 同样别忘记了导包和创建实例

def two():
    return "创建路由的方法二,返回值为: two"
app.add_url_rule('/two',view_func=two)

运行 : 

 反向生成URL

endpoint 相当于创建了一个别名 

在反向生成的时候 需要从 flask 里面导入 url_for

from flask import url_for

用于反向生成的时候才写别名

如果不起别名,则 默认是其函数名

@app.route('/index',methods=['GET','POST'],endpoint="first")
def index():
    h1 = url_for("first")
    h2 = url_for("login")       # 不起别名 使用默认名
    h3 = url_for("logout")      # 不起别名 使用默认名
    print(h1,h2,h3)
    return "index"

@app.route('/login',methods=['GET','POST'])
def login():
    return "login"

@app.route('/logout',methods=['GET','POST'])
def logout():
    return "logout"

 注意事项 !!!

在我第一遍做简单flask的时候出现的一个问题

做到第二个项目的时候页面出现的却是第一个项目的结果

也就是在我想运行 反向生成URL.py 文件的时候 输入了我设置的新rule  可是网页一直显示 Not Found 并且输入第一个项目的rule可以正常显示

原因 :

1. 要么是你的上一个项目运行没有终止

2.要么是端口(12.0.0.1:5000)被占用了

解决 :

如果是你上一项目没有终止,正常情况下可以点击红色方块结束程序运行,终止掉程序运行

 当建立多个项目时,127.0.0.1:5000这个端口被反复占用,导致pycharm无法杀掉上一个项目的进程,这时需要手动杀死进程

快捷键 Win + R 打开 cmd

在你的终端命令行输入

netstat -ano|findstr “5000”

然后杀掉对应 pid  

结束进程

taskkill /pid 52824 /f

再次运行你的 .py 文件就可以正常显示了

总结 :

在运行 flask 程序时

通常大部分人操作时和python文件一样运行 右击然后run

右击run程序出来的结果

 容易忘记停止并且可能会出现端口堵塞等问题

有一种改进方式

在下方有一个 Terminal (终端) 的标识

 用终端去运行,点击它

 Ctrl + C 快捷键结束

自定义路由转换器

@app.route('/index/<int:nid>',methods=['GET','POST'])
def index(nid):
    print("int类型: ", nid)
    return "返回结果是: int类型的nid"

 运行 :

重定向

这个在很多场景都可以使用

打个比方

现在公司里有了一个用了很久的一个网站,

然后让公司里的程序员去对这个网站做一个优化改进

可是原来的网站网址被公司员工已经用了N多边了,网址都已经刻入DNA里了

现在优化好的新的网站网址告诉公司员工们,

为了避免一些员工习惯性的登入旧网站网址,

程序员要对旧网站网址增添一个重定向,也就是说 如果有员工习惯性的登入旧网站网址,那么这个重定向就起作用了,它会跳转到i新网站网址上去

@app.route('/old',methods=['GET','POST'],redirect_to='/new')
def old():
    return "老功能"

@app.route('/new',methods=['GET','POST'])
def new():
    return "新功能"

运行 :

 输入 old 会自动跳转到 new 网页上

  • 20
    点赞
  • 78
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
`@app.route` 和 `@blog.route` 是 Flask Web 框架中的装饰器,用于定义路由和视图函数。 `@app.route` 是 Flask 应用程序对象 `app` 的装饰器,用于定义全局的路由和视图函数。它可以在应用程序的顶层中使用,用于处理整个应用程序的路由。例如: ```python from flask import Flask app = Flask(__name__) @app.route('/') def index(): return 'Hello, World!' if __name__ == '__main__': app.run() ``` 在上面的示例中,`@app.route('/')` 定义了根路径 `/` 的路由,并将其与 `index` 视图函数关联。 `@blog.route` 是蓝图对象 `blog` 的装饰器,用于定义特定模块或功能的路由和视图函数。蓝图是一种用于组织和管理 Flask 应用程序的模块化方式。通过使用蓝图,你可以将应用程序划分为多个模块,每个模块具有自己的路由和视图函数。例如: ```python from flask import Blueprint blog = Blueprint('blog', __name__) @blog.route('/') def index(): return 'Welcome to the blog!' @blog.route('/post/<int:post_id>') def show_post(post_id): return f'Showing post {post_id}' # 在应用程序中注册蓝图 app.register_blueprint(blog, url_prefix='/blog') ``` 在上面的示例中,`@blog.route('/')` 定义了蓝图 `blog` 的根路径 `/` 的路由,并将其与 `index` 视图函数关联。通过在应用程序中注册蓝图,并指定 URL 前缀为 `/blog`,我们可以将所有与博客相关的路由都放置在 `/blog` 路径下。 总结来说,`@app.route` 用于定义全局的路由和视图函数,而 `@blog.route` 用于定义蓝图的路由和视图函数。它们的区别在于作用范围和组织方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值