当前位置:  首页>> 技术小册>> Flask框架零基础入门与实战开发

在上篇文章我们成功运行了Flask框架——第一个Flask程序,这篇文章我们学习Flask框架——路由(Route)。

上篇文章运行了Flask应用程序,访问http://127.0.0.1:5000/ 网页后,网页显示内容是Hello World!字符,那么为什么不是显示其他字符呢?

我们从源代码和终端运行结果分析,如下图所示:

我们发现网址最后的/和源代码中的@app.route(‘/‘)路由装饰器是对应的,其访问逻辑如下图所示:

客户端访问服务器中的http://127.0.0.1:5000/ ,服务器接收到请求后,先去查找有没有http://127.0.0.1:5000/ ,有则响应调用@app.route(‘/‘)路由装饰器中的视图函数,否则返回404。所以这里就打印出了Hello World!
所以控制什么URL显示什么内容的是路由及其视图函数。

路由(Route)

在Web应用程序都通过路由技术使用URL链接来控制网页显示的内容,只要知道URL链接,即使没有主页导航也可以直接访问所需网页。

在Flask框架中使用route()路由装饰器将URL绑定到视图函数中,示例代码如下所示:

  1. from flask import Flask
  2. app=Flask(__name__)
  3. @app.route('/hello') #路由装饰器
  4. def hello_world(): #视图函数
  5. return 'hello world'
  6. if __name__ == '__main__':
  7. app.run()

这里的将URL链接为http://127.0.0.1:5000/hello的网页绑定在hello_world()函数中,这样,当用户访问该URL链接时,就会调动hello_world()视图函数,这个视图函数执行结果是返回hello world,所以在浏览器中显示内容为hello world。

除了使用@app.route()路由装饰器将URL链接与视图函数绑定,我们还可以使用add_url_rule()方法将URL链接与视图函数绑定,add_url_rule()方法语法结构为:

  1. app.add_url_rule(rule='',endpoint=None,view_func=None,options='')

其中:

rule:函数对应的url规则,满足条件和app.route()的第一个参数一样,必须以’/‘开始;

endpoint:站点,就是在使用url_for()进行反转的时候,这个里面传入的第一个参数就是这个endpoint对应的值。这个值也可以不指定,那么默认就会使用函数的名字作为endpoint的值;

view_func:对应的函数;

options:该路由规则的方法(get或post)。

示例代码如下所示:

  1. from flask import Flask
  2. app=Flask(__name__)
  3. def hello_world():
  4. return "Hello World!"
  5. app.add_url_rule('/hello',view_func=hello_world)
  6. if __name__ == '__main__':
  7. app.run()

使用add_url_rule()方法与使用@app.route()路由装饰器将URL链接与函数绑定的效果一样,但我们推荐使用@app.route()路由装饰器来绑定。

路由规则

为了给URL链接增加变量,我们可以定义路由规则,把变量部分用特定的字段标记成,其作为关键字参数传递给规则所关联的视图函数。

示例代码如下所示:

  1. from flask import Flask
  2. app=Flask(__name__)
  3. data={'a':'北京','b':'上海','c':'深圳'}
  4. @app.route('/getcity/<city>')
  5. def get_city(city):
  6. return data.get(city)
  7. if __name__ == '__main__':
  8. app.run()

运行Flask程序后,我们访问http://127.0.0.1:8080/getcity/a时,网页就会显示北京。

当然我们还可以通过转换器来指定规则,转换器有:

string:接收字符串;

int:接收整数;

float:接收浮点数;

path:接收字符串路径;

uuid:接收uuid字符串。

示例代码如下所示:

  1. from flask import Flask
  2. app=Flask(__name__)
  3. #整型
  4. @app.route('/getnum/<int:num>')
  5. def get_num(num):
  6. return str(num)
  7. #路径
  8. @app.route('/path/<path:p>')
  9. def get_path(p):
  10. return p
  11. #唯一标识
  12. @app.route('/uuid/<uuid:uid>')
  13. def get_uuid(uid):
  14. return str(uid)
  15. if __name__ == '__main__':
  16. app.run()

运行Flask程序后,我们分别访问下面几个URL链接:

http://127.0.0.1:8080/getnum/10
http://127.0.0.1:8080/path/first/1
http://127.0.0.1:8080/uuid/dac401f1-8622-4a03-b850-6f3049d30d35
网页就会分别显示以下内容:

10
first/1
dac401f1-8622-4a03-b850-6f3049d30d35

这里需要注意的是:

函数的返回类型默认是字符串类型;

函数返回类型必须是字符串、dict、tuple、响应实例或WSGI可调用;

  1. <varable_name>字段必须要和函数传入的参数名一致。

环境配置

运行了上面的示例代码中,是不是觉得很不方便,每次修改Flask程序的代码就要在终端停止Flask程序的运行,再启动Flask程序才能测试修改后的运行结果,而且在终端中老是有个WARNING警告。

这时我们可以通过如下代码进行环境配置:

  1. app.config['配置参数']='参数值'

我们可以配置debug调试模式使服务器自动加载修改后的代码,示例代码如下所示:

  1. from flask import Flask
  2. app=Flask(__name__)
  3. print(app.config) #打印app配置
  4. app.config['DEBUG']=True
  5. @app.route('/')
  6. def index():
  7. return "第一个Flask"
  8. if __name__ == '__main__':
  9. app.run()

调试模式,当debug=True时,只要代码改变,服务器就会自动加载最新的代码,只要刷新网页就呈现最新的网页,适用于开发环境,默认为Flase,适用于产品环境;

为了满足我们的开发需求,只是配置debug远远不够的,运行上面的Flask程序,如下图所示:

可以发现有那么多配置,随着Flask项目的开发,需要的配置会越来越多,配置都通过app.config[‘配置参数’]=’参数值’来配置,这显然是不可取的,不可能在启动文件中编写配置的代码,而且启动文件越简单越好,那么我们可以创建一个setting.py文件来存放配置。

settings.py示例代码如下:

  1. #配置文件
  2. ENV='development'
  3. DEBUG='True'

写好配置文件后,我们可以使用app.config.from_object()来加载我们的配置,示例代码如下所示:

  1. #配置文件
  2. ENV='development'
  3. DEBUG='True'

运行结果如下图所示:

这样我们就成功修改了配置。


该分类下的相关小册推荐: