Flask 中的MTV架构之Views

1、MVC与MTV
1.1 MVC

​ M:model,模型,数据模型

​ V:view,视图,负责数据展示

​ C:controller,控制器,负责业务逻辑的处理

1.2 MTV

​ M:model,模型,就是数据模型

​ T:templates,模板,负责数据展示

​ V:view function,视图函数,负责业务逻辑的处理

2、Views(请求与响应)
2.1 内置对象

​ 1、app
获得应用对象:app = Flask(name)
配置应用参数:app.config[‘UPLOAD_FOLDER’] = os.getcwd()
从配置类中加载配置:app.config.from_object(configClass)
通用配置类实例

# 通用配置
class Config:
# 秘钥
SECRET_KEY = os.environ.get('SECRET_KEY') or '123456' # 数据库操作
SQLALCHEMY_COMMIT_ON_TEARDOWN = True
SQLALCHEMY_TRACK_MODIFICATIONS = False # 邮件发送
MAIL_SERVER = os.environ.get('MAIL_SERVER') or 'smtp.qq.com'
MAIL_USERNAME = os.environ.get('MAIL_USERNAME') or 'xxx@qq.com'
MAIL_PASSWORD = os.environ.get('MAIL_PASSWORD') or '123456' # bootstrap使用本地库
BOOTSTRAP_SERVE_LOCAL = True # 上传文件
MAX_CONTENT_LENGTH = 8 * 1024 * 1024
UPLOADED_PHOTOS_DEST = os.path.join(base_dir, 'static/upload') # 初始化函数,完成特定环境的初始化
@staticmethod
def init_app(app):
pass

​ 获得应用上下文:app.app_context()
蓝图:app.register_blueprint(blueprint, url_prefix=url_prefix)
2、current_app
获得当前app实例:app = current_app._get_current_object()
获得app配置的值:current_app.config[‘SECRET_KEY’]
3、 g

​ 全局变量存储器

 # g对象是全局变量储存容器,其中可以随意存储任何变量,
#作用域覆盖所有的py文件和模板文件
g.name = '哈士奇'

​ 在Templates模板里就可以直接使用g.name

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</ttle>
</head>
<body> {# g对象是全局变量储存容器,其中可以随意存储任何变量,
作用域覆盖所有的py文件和模板文件#}
<h1>Hello {{ g.name }}!</h1>
</body>
</html>

​ 4、request

​ 请求对象,保存了客户端所有的HTTP的请求信息

​ 请求中的信息

   @app.route('/request/')
def req():
# 完整的请求URL
# return request.url # 基本路由地址,不包括get参数
# return request.base_url # 只有主机和端口号
# return request.host_url # 只包含装饰器中的路由地址
# return request.path # 请求方法类型
# return request.method # 客户端的IP
# return request.remote_addr # 获取GET参数
# return request.args['name'] # 获取请求头信息
return request.headers['User-Agent']

​ 其它
获得上传的文件:file = request.files.get(‘photo’)
获得GET请求参数:page = request.args.get(‘page’, 1, type=int)
5、session

​ 用户会话,用于保存需要’记住’的会话信息

​ 服务端存储技术

​ 设置秘钥

方法1(容易暴露密码):
设置秘钥,用于加密解密的字符串,不只是用于session
app.config['SECRET_KEY'] = '123456' 方法2(使用环境变量设置):
app.config['SECRET_KEY'] = os.environ.get('SECRET_KEY') or '123456'

​ 设置session

    @app.route('/set_session/')
def set_session():
session['user'] = 'xiaoqiao'
return 'session已设置'

​ 获取session

@app.route('/get_session/')
def get_session():
return session.get('user', None)
2.2 钩子函数

​ 第一次请求之前 :before_first_request
每次请求之前 :before_request
每次请求之后,前提是没有异常 :after_request
每次请求之后,即使有异常发生 :teardown_request
实例

@app.before_first_request
def beforeFirstRequest():
print('beforeFirstRequest')
@app.before_request
def beforeRequest():
print('beforeRequest', request)
@app.after_request
def afterRequest(resp):
print('afterRequest', resp)
return resp
@app.teardown_request
def tearDownRequest(resp):
print('tearDownRequest', resp)
return resp
2.3带参路由

​ 带参路由

@app.route('/welcome/<name>')
def welcome(name):
return 'Hello %s !' % name

​ 指定参数类型(默认string)

@app.route('/user/<int:uid>')
def show(uid):
return '%d 号,你好!' % uid

​ path类型(参数中的/不再作为分隔符)

@app.route('/path/<path:p>')
def path(p):
return p
1.路由末尾的'/'建议都加上,因为需要的时候浏览器会自动加上,
输入时加不加都行
2.若需要制定参数,将参数写在<>中,视图函数参数要与路由参数一致
3.若需要知道参数类型,如:int/float/path等,写在参数前,
用':'与参数隔开
4.不指定类型,参数默认是string,path其实也是字符串,只是'/'不再是分隔符
2.4 请求与响应

​ request
请求对象,保存了客户端所有的HTTP的请求信息

​ 请求中的信息

   @app.route('/request/')
def req():
# 完整的请求URL
# return request.url # 基本路由地址,不包括get参数
# return request.base_url # 只有主机和端口号
# return request.host_url # 只包含装饰器中的路由地址
# return request.path # 请求方法类型
# return request.method # 客户端的IP
# return request.remote_addr # 获取GET参数
# return request.args['name'] # 获取请求头信息
return request.headers['User-Agent']

​ 其它
获得上传的文件:file = request.files.get(‘photo’)
获得GET请求参数:page = request.args.get(‘page’, 1, type=int)
response
服务器给客户端的响应

   @app.route('/response/')
def response():
# 默认状态码200
# return 'OK' # 在响应的后面指定状态码
# return 'Page not found', 404 # 先构造一个响应(也可以指定状态码),然后返回
resp = make_response('这是通过函数构造的响应', 404) return resp
2.5重定向
  @app.route('/redirect/')
def old():
# return '旧的内容'
# 重定向,响应指定一个路由地址
#return redirect('/new/')
# 根据视图函数,反向的构造出来路由地址,传递的参数是视图函数名
# return url_for('req')
# 构造带参数的路由,直接写在后面即可
# return url_for('welcome', name='xiaoming')
return redirect(url_for('new')) @app.route('/new/')
def new():
return '新的内容'
2.6 终止和处理错误

​ 抛出错误并终止

    @app.route('/abort/')
def err():
abort(404)
return 'abort测试'

​ 处理错误

@app.errorhandler(404)
def page_not_found(e):
# 渲染指定模板
return render_template('errors/404.html')
2.7 会话控制

​ cookie

​ 客户端存储技术

​ 设置cookie

    @app.route('/set_cookie/')
def set_cookie():
resp = make_response('cookie已设置')
expires = time.time() + 10 # 设置cookie,可以指定过期时间
resp.set_cookie('name', 'xiaoming', expires=expires)
return resp

​ 获取cookie

    @app.route('/get_cookie/')
def get_cookie():
return request.cookies.get('name') or None
2.8 session

​ 设置秘钥

#方法1(容易暴露密码):
#设置秘钥,用于加密解密的字符串,不只是用于session
app.config['SECRET_KEY'] = '123456' 方法2(使用环境变量设置):
app.config['SECRET_KEY'] = os.environ.get('SECRET_KEY') or '123456'

​ 设置session

    @app.route('/set_session/')
def set_session():
session['user'] = 'xiaoqiao'
return 'session已设置'

​ 获取session

@app.route('/get_session/')
def get_session():
return session.get('user', None)
2.9 blueprint

a.什么是蓝图?

一个蓝图定义了可用于单个应用的视图,模板,静态文件等等的集合。

b.什么时候会用到蓝图?

使用蓝图的好处是将你的应用组织成不同的组件,比如把admin,user相关的视图方法分为两个组件,一个是admin组件,一个是user组件.这时我们可以创建两个蓝图实现这两个独立的组件。

c.定义蓝图

   from flask import Blueprint

   # 创建蓝图对象
user = Blueprint('user', __name__) # 添加路由(视图函数)
@user.route('/login/')
def login():
return '欢迎登录' @user.route('/register/')
def register():
return '欢迎注册'

​ d.注册蓝图

   # 在使用的地方进行注册
# 注册蓝图,未注册的蓝图处于休眠状态(无法使用),
#可以通过url_prefix指定前缀,
#当request.url是以/user开头的情况下才会
#通过注册的蓝图的视图方法处理请求并返回
from user import user
app.register_blueprint(user, url_prefix='/user')

【后记】:如果文章对您有帮助,打赏下呗。微信 1257309054,欢迎交流学习*_*
微信

支付宝

Flask 中的MTV架构之Views的更多相关文章

  1. Flask 中的MTV架构之Models

    Flask 中的MTV架构之Models 1.Models(数据模型) 1.1 flask-sqlalchemy(数据库) ​ 说明:提供了大多数关系型数据库的支持,而且提供了ORM # 安装: pi ...

  2. Flask中的MTV架构之Templates

    Flask 中的MTV架构之Templates 关注公众号"轻松学编程"了解更多. 1.Templates(模板引擎) 1.1 说明 ​ 模板文件就是按照特定规则书写的一个负责展示 ...

  3. python框架Django中的MTV架构

    MTV架构 关注公众号"轻松学编程"了解更多. ​ 通过V对M和T进行连接,用户通过T(界面)对服务器进行访问(发送请求),T把请求传给V(调度),V调用M(数据模型)获取数据,把 ...

  4. django上课笔记6-MVC,MTV架构-中间件-初识Form组件

    一.MVC,MTV架构 models(数据库,模型) views(html模板) controllers(业务逻辑处理) --> MVC models(数据库,模型) templates(htm ...

  5. [Python自学] day-18 (2) (MTV架构、Django框架、模板语言)

    一.实现一个简单的Web服务器 使用Python标准库提供的独立WSGI服务器来实现MVC架构. 首先,实现一个简单的Web服务器: from wsgiref.simple_server import ...

  6. 转:Android开发中的MVP架构(最后链接资源不错)

    Android开发中的MVP架构 最近越来越多的人开始谈论架构.我周围的同事和工程师也是如此.尽管我还不是特别深入理解MVP和DDD,但是我们的新项目还是决定通过MVP来构建. 这篇文章是我通过研究和 ...

  7. 转: Android开发中的MVP架构详解(附加链接比较不错)

    转: http://www.codeceo.com/article/android-mvp-artch.html 最近越来越多的人开始谈论架构.我周围的同事和工程师也是如此.尽管我还不是特别深入理解M ...

  8. 设计模式笔记之二:Android开发中的MVP架构(转)

    写在前面,本博客来源于公众号文章:http://mp.weixin.qq.com/s?__biz=MzA3MDMyMjkzNg==&mid=402435540&idx=1&sn ...

  9. flask框架----整合Flask中的目录结构

    一.SQLAlchemy-Utils 由于sqlalchemy中没有提供choice方法,所以借助SQLAlchemy-Utils组件提供的choice方法 import datetime from ...

随机推荐

  1. 报表工具FastReport VCL 最新版发布!

    新功能 为主要包类添加了类引用 在报表设计器中添加了SQL编辑器的自定义 为TfrxReport的操作添加了延迟的命令池:PrepareReport,ShowReport,LoadFrom.可以调用R ...

  2. 剑指offer-二叉树

    1. 平衡二叉树 输入一棵二叉树,判断该二叉树是否是平衡二叉树. 解: 要么是一颗空树,要么左右子树都是平衡二叉树且左右子树深度之差不超过1 1 # class TreeNode: 2 # def _ ...

  3. IDEA2020版最佳优化思路(中文界面)

    IDEA优化 基于当前最新版idea 2020.1版本进行设置 设置中文 在idea 2020.1版本后官方是支持中文啦 先上效果图 设置方法 这里需要下载官方的中文包 鼠标悬停提示 效果图 设置方法 ...

  4. 一种基于均值不等式的Listwise损失函数

    一种基于均值不等式的Listwise损失函数 1 前言 1.1 Learning to Rank 简介 Learning to Rank (LTR) , 也被叫做排序学习, 是搜索中的重要技术, 其目 ...

  5. 027 01 Android 零基础入门 01 Java基础语法 03 Java运算符 07 逻辑“与”运算符

    027 01 Android 零基础入门 01 Java基础语法 03 Java运算符 07 逻辑"与"运算符 本文知识点:Java中的逻辑"与"运算符 逻辑运 ...

  6. 2-Java面试-面向对象

    Java面试问题-面向对象 Q1.什么是多态? 多态被简要描述为"一个接口,许多实现".多态性是能够在不同上下文中为某事物赋予不同含义或用法的一种特征-具体来说,就是允许诸如变量, ...

  7. Create a cursor from hardcoded array instead of DB

    https://stackoverflow.com/questions/18290864/create-a-cursor-from-hardcoded-array-instead-of-db Crea ...

  8. ISCSI共享

    共享存储 ISCSI共享 服务端 软件安装 Install epel-release: # yum install epel-release Install scsi-target-utils rpm ...

  9. 多测师讲解python _类(原始版)_高级讲师肖sir

    # Python中的类: '''定义一个类:class +名称=类 在类当中定义:def +名称=实例方法(self)与类平齐def +名称=普通函数定义一个函数:def +名称=函数在函数中:函数( ...

  10. pytest文档53-命令行实时输出错误信息(pytest-instafail)

    前言 pytest 运行全部用例的时候,在控制台会先显示用例的运行结果(.或F), 用例全部运行完成后最后把报错信息全部一起抛出到控制台. 这样我们每次都需要等用例运行结束,才知道为什么报错,不方便实 ...