关于Flask 视图介绍
作者:tigeriaf 发布时间:2022-10-21 15:07:34
1、视图函数
之前的文章说过,在 Flask 中路由是请求的 url 与处理函数之间的映射,使用app.route装饰器将处理函数和 url 绑定,路由绑定的处理函数就被成为视图函数。
@app.route('/user/<name>')
def hello_user(name):
return 'Hello {}!'.format(name)
上面的hello_user()
函数就是一个简单的视图函数。
当然我们也可以不使用app.route
装饰器,使用app.add_url_rule()
方法也可将视图函数和 url
进行绑定,实际上装饰器app.route
也是调用的app.add_url_rule()
方法。
def hello():
return 'hello Flask!'
app.add_url_rule('/hello', view_func=hello)
通过app.add_url_rule()
方法,可以将路由同视图分开,方便将路由进行统一管理。
2、类视图
我们之前包括上面使用的,都是基于函数的视图,这虽然是最简单便捷的用法,但是不容易扩展,其实视图函数也可以基于类来实现,好处就是类支持继承,可以把一些共性的代码放在父类中,其他子类可以继承,在某些情况下,使用类更合理,更易于扩展。
类视图分为标准类视图和基于调度方法的类视图,下面分别介绍一下。
2.1 标准类视图
标准类视图的写法:
父类必须继承
flask.views.View
类子类实现
dispatch_request()
方法,完成自身的业务逻辑并返回结果子类使用
app.add_url_rule()
进行注册,其中view_func
参数使用as_view()
方法做类方法转换如果注册时指定了
endpoint
参数,endpoint
的值会覆盖指定的视图名称,使用url_for
时就必须使用endpoint
指定的值
具体使用方式如下:
from flask.views import View
class ParentView(View):
def __init__(self):
super().__init__()
# 公共部分信息
self.public_data = 'Flask Web App'
class Index(ParentView):
methods = ['GET']
def dispatch_request(self):
return self.public_data + " index"
class User(ParentView):
methods = ['POST']
def dispatch_request(self):
return self.public_data + " user"
app.add_url_rule('/index', endpoint='index', view_func=Index.as_view('index'))
app.add_url_rule('/user', endpoint='user', view_func=User.as_view('user'))
上述代码中创建了一个 ParentView
类,继承自 flask.views.View
类,然后创建了 Index
和 User
两个类继承自 ParentView
类,并分别重写实现了dispatch_request()
函数,使用了父类 ParentView
的属性public_data
, 实现自己的业务逻辑。然后我们通过as_view()
方法把类转换为实际的视图函数,as_view()
必须传入一个唯一不重复的视图名。此后,这个视图由app.add_url_rule()
方法和指定路由绑定。
类视图支持的 HTTP
请求方法由视图类变量methods
指定,默认只支持 GET 请求。
2.1.1 基于方法的视图
如果视图支持多种 HTTP 请求方法的话,之前我们都是在视图函数中进行判断,根据不同的请求方法执行不同的业务逻辑,那有没有更简单的方法呢?是有的,Flask
中的方法类视图 flask.views.MethodView
就可以做到,它是 flask.views.View
的子类,通过定义和请求方式同名的小写方法来完成了逻辑处理,不必提供methods属性,每个 HTTP 方法都映射到一个具有相同名称(小写)的函数。
下面看下详细使用方法。
from flask.views import MethodView
class UserView(MethodView):
def get(self):
user_id = request.args.get("user_id")
return "Hello user:{}".format(user_id)
def post(self):
name = request.form.get("name")
password = request.form.get("password")
if name == "admin" and password == "123456":
return "hello admin!"
else:
return "not allow!"
app.add_url_rule('/user/get_info', view_func=UserView.as_view('get'))
app.add_url_rule('/user/login', view_func=UserView.as_view('post'))
代码中定义的get()
函数用于处理 GET 请求,post()
函数用于处理 POST 请求,代码中省去了 HTTP 请求方法的判断语句,而且是不是更加RESTFul
一些了。
请求测试:
来源:https://juejin.cn/post/7032867176088338445


猜你喜欢
- 图像可能在生成、传输或者采集过程中夹带了噪声,去噪声是图像处理中常用的手法。通常去噪声用滤波的方法,比如中值滤波、均值滤波。但是那样的算法不
- 又一个js加密工具:js混淆,完整源代码如下,有点长呵呵:<HTML><HEAD><TITLE>Cunf
- 实例如下所示:u = array([[1,2],[3,4]])m = u.tolist()#转换为listm.remove(m[0])#移除
- 目录 一、前言1.1 什么是 import 机制?1.2 import 是如何执行的?二、import 机制概览三、import
- A.截取从字符串左边开始N个字符 Declare @S1 varchar(100) Select @S1='http://www.x
- 1. 范数示例代码:import torcha = torch.full([8], 1)b = a.reshape([2, 4])c = a
- MAC下MYSQL5.7.17无法连接的问题,下载安装完SQLBench_community 6.3.9后新建MYSQL CONNECTIO
- 1. viper的介绍viper是go一个强大的流行的配置解决方案的库。viper是spf13的另外一个重量级库。有大量项目都使用该库,比如
- <% Function XMLEncode(byVal sText) sText = Replace(sText, "&am
- 最近项目中有一个小需求,查找json文件中某个key或者value的路径,所以就写了一个简单的小脚本,比较粗糙。#!/usr/bin/env
- 关于string的split 和 join 方法对导入os模块进行os.path.splie()/os.path.join() 貌似是处理机
- 一、页的概览我们往 MySQL 插入的数据最终都是存在页中的。在 InnoDB 中的设计中,页与页之间是通过一个双向链表连接起来。而存储在页
- 1.安装pymysql:pip install pymysql (在命令行窗口中执行)2.卸载pymysql:pip uninstall p
- 1、引言需要把.dat 格式 转化成 .txt格式2、实现##python批量更换后缀名import os# 列出当前目录下所有的文件fil
- 本文实例讲述了python实现的简单抽奖系统。分享给大家供大家参考。具体实现方法如下:#!/usr/bin/env python#codin
- FP代表频繁模式(Frequent Pattern),算法主要分为两个步骤:FP-tree构建、挖掘频繁项集。FP树表示法FP树通过逐个读入
- 数组都是从0开始。javascript是arrayname[i],而vbscript是arrayname(i) javascript的字符串
- 1.Django的简介Django是一个基于MVC构造的框架。但是在Django中,控制器接受用户输入的部分由框架自行处理,所以 Djang
- 前言本博主将用CSDN记录软件开发求学之路上亲身所得与所学的心得与知识,有兴趣的小伙伴可以关注博主!也许一个人独行,可以走的很快,但是一群人
- python中的dir()函数是一个非常重要的函数,它可以帮助我们查看函数的功能和特性。中文说明:不带参数时,返回当前范围内的变量、方法和定