4-flask-cbv源码、Jinja2模板、请求响应、flask中的session、flask项目参考

2023-11-20 13:01

本文主要是介绍4-flask-cbv源码、Jinja2模板、请求响应、flask中的session、flask项目参考,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 flask中cbv源码
2 Jinja2模板
3 请求响应
4 flask中的session
5 flask项目参考

1 flask中cbv源码

***flask的官网文档:***https://flask.palletsprojects.com/en/3.0.x/views/1 cbv源码执行流程'''1 请求来了,路由匹配成功---》执行ItemAPI.as_view('item')()--->view加括号执行2 ItemAPI.as_view('item')执行结果:就是View中as_view方法中的闭包函数 view3 view()--->执行self.dispatch_request()---》执行MethodView的dispatch_requestdef dispatch_request(self, **kwargs):meth = getattr(self, request.method.lower(), None)return meth(**kwargs)4 如果是get请求,就会执行视图类中的get方法class View:@classmethoddef as_view()def view():self.dispatch_request()return view'''2  endpoint 的使用app.add_url_rule('/item', endpoint='xxx',view_func=ItemAPI.as_view('item'))如果写了endpoint---》别名以它为准,如果不写以as_view的参数为准3 逻辑:1 app.add_url_rule('/item',endpoint='xxx', view_func=ItemAPI.as_view('item'))2 endpoint = _endpoint_from_view_func(view_func)如果endpoint没传,就会走这句view_func 是  ItemAPI.as_view('item')  它就是 view3 _endpoint_from_view_func(view_func)---》返回了传入的函数的名字return view_func.__name__4 如果上面传入了ItemAPI.as_view('item'),它的函数名就是view---》endpoint就是view## 总结:endpoint如果不传,会以视图函数的函数名作为endpoint-fbv:如果不写endpoint,会以函数名作为endpoint,但是如果多个视图函数加了同一个装饰器,又没有指定endpoint,就会出错了-cbv:调用as_view一定要传入一个字符串---》如果endpoint没写,endpoint就是传入的这个字符串,如果写了,这个字符串没用如果传了,直接以endpoint传入的作为endpoint### cbv中加装饰器1 使用步骤:在类中加入类属性:class ItemAPI(MethodView):decorators = [装饰器,装饰器2]def get(self):# print(url_for('xxx'))print(url_for('item'))return 'get'2 if cls.decorators:for decorator in cls.decorators:view = decorator(view)   '''@装饰器def view()'''
### 整个cbv执行流程
# View的as_view
@classmethod
def as_view(cls, name, *class_args, **class_kwargs) :def view(**kwargs):return self.dispatch_request(**kwargs)if cls.decorators:   # 咱们的装饰器for decorator in cls.decorators: #每次拿出一个装饰器,view = decorator(view) # 装饰器语法糖干的事: 把被装饰的函数当参数传入到装饰器,返回结果赋值给被装饰的函数,一个个用装饰器包装viewview.__name__ = namereturn view# self.dispatch_request---》MethodView
def dispatch_request(self, **kwargs) :# 取到request.method.lower()请求方式小写 ---》假设是get请求get# meth是 cbv中 以get命名的方法,反射出来了meth = getattr(self, request.method.lower(), None)return meth(**kwargs) # 执行cbv中跟请求方式同名的方法
def register_api(app, model, name):item = ItemAPI.as_view(f"{name}-item", model)group = GroupAPI.as_view(f"{name}-group", model)app.add_url_rule(f"/{name}/<int:id>", view_func=item)  # get put  deleteapp.add_url_rule(f"/{name}/", view_func=group)   #post get register_api(app, User, "users")
register_api(app, Story, "stories")

2 Jinja2模板

# flask使用了Jinja,flask提供了文档,也可以去Jinja官网看
https://flask.palletsprojects.com/en/3.0.x/
https://jinja.palletsprojects.com/en/3.1.x/# 总结:之前学过dtl-{{变量/简单表达式/函数}}-{%if/for %} {%endif%}  {%endfor%}-比dtl强大 ,Jinja中可以加括号-字典取值,列表取值跟python语言一样,之前dtl 通过 .取值-过滤器,标签-extends,include 跟之前一样

3 请求响应

# 所有web:请求对象,响应对象(go,java,ptyhon)django:request(每个请求一个request),新手四件套flask: requset:全局的,但是也是每个请求一个request,新手三件套# request  全局对象,用起来,跟之前django的一样# request.method  请求的方法# request.args  get请求提交的数据# request.form   post请求提交的数据# request.values  post和get提交的数据总和# request.cookies  客户端所带的cookie# request.headers  请求头# request.path     不带域名,请求路径# request.full_path  不带域名,带参数的请求路径# request.url           带域名带参数的请求路径# request.base_url		带域名请求路径# request.url_root      域名# request.host_url		域名# request.host			服务端地址# request.files# obj = request.files['the_file_name']# obj.save('/var/www/uploads/' + secure_filename(f.filename))# 响应 response---》四件套-return '字符串'-return render_template('index.html',name=lqz,age=19)-return redirect(url_for(别名))-return jsonify(字典,列表) # 往cookie中写数据--->四件套需要使用obj=make_response('index')obj.set_cookies()  # 跟之前一样# obj.headers[]

4 session

# cookie 机制
# 设置
obj=make_response('index')
obj.set_cookies('name','lqz')
# 取
request.cookie.get('name')# session机制1 设置秘钥2 写入sessionsession['username']='xxx'3 取出sessionusername = session.get('username')

在这里插入图片描述

5 flask项目参考

# 开源项目阅读
https://toscode.mulanos.cn/pear-admin/pear-admin-flask# 1 git clone https://toscode.mulanos.cn/pear-admin/pear-admin-flask
# 2 使用pycharm打开
# 3 创建虚拟环境,装依赖
# 4 改配置文件MYSQL_USERNAME = "root"MYSQL_PASSWORD = "lqz123?"MYSQL_HOST = "127.0.0.1"MYSQL_PORT = 3306MYSQL_DATABASE = "PearAdminFlask"# 数据库的配置信息# SQLALCHEMY_DATABASE_URI = 'sqlite:///../pear.db'SQLALCHEMY_DATABASE_URI = f"mysql+pymysql://{MYSQL_USERNAME}:{urlquote(MYSQL_PASSWORD)}@{MYSQL_HOST}:{MYSQL_PORT}/{MYSQL_DATABASE}?charset=utf8mb4"# 5 创建数据库  PearAdminFlask# 6 执行初始化flask db init#7 migrate.bat
# 8 flask admin init
# 9 启动
run.bat# 10 改代码---》密码不判断

这篇关于4-flask-cbv源码、Jinja2模板、请求响应、flask中的session、flask项目参考的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/394798

相关文章

Java 正则表达式URL 匹配与源码全解析

《Java正则表达式URL匹配与源码全解析》在Web应用开发中,我们经常需要对URL进行格式验证,今天我们结合Java的Pattern和Matcher类,深入理解正则表达式在实际应用中... 目录1.正则表达式分解:2. 添加域名匹配 (2)3. 添加路径和查询参数匹配 (3) 4. 最终优化版本5.设计思

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

Spring Boot项目部署命令java -jar的各种参数及作用详解

《SpringBoot项目部署命令java-jar的各种参数及作用详解》:本文主要介绍SpringBoot项目部署命令java-jar的各种参数及作用的相关资料,包括设置内存大小、垃圾回收... 目录前言一、基础命令结构二、常见的 Java 命令参数1. 设置内存大小2. 配置垃圾回收器3. 配置线程栈大小

鸿蒙中Axios数据请求的封装和配置方法

《鸿蒙中Axios数据请求的封装和配置方法》:本文主要介绍鸿蒙中Axios数据请求的封装和配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.配置权限 应用级权限和系统级权限2.配置网络请求的代码3.下载在Entry中 下载AxIOS4.封装Htt

Spring Boot项目中结合MyBatis实现MySQL的自动主从切换功能

《SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能》:本文主要介绍SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能,本文分步骤给大家介绍的... 目录原理解析1. mysql主从复制(Master-Slave Replication)2. 读写分离3.

springboot filter实现请求响应全链路拦截

《springbootfilter实现请求响应全链路拦截》这篇文章主要为大家详细介绍了SpringBoot如何结合Filter同时拦截请求和响应,从而实现​​日志采集自动化,感兴趣的小伙伴可以跟随小... 目录一、为什么你需要这个过滤器?​​​二、核心实现:一个Filter搞定双向数据流​​​​三、完整代码

Python 安装和配置flask, flask_cors的图文教程

《Python安装和配置flask,flask_cors的图文教程》:本文主要介绍Python安装和配置flask,flask_cors的图文教程,本文通过图文并茂的形式给大家介绍的非常详细,... 目录一.python安装:二,配置环境变量,三:检查Python安装和环境变量,四:安装flask和flas