flask基础二
内容有:1、配置文件处理,2、路由系统,3、视图,4、请求,5、响应,6、模板渲染,7、session,8、flash,9、中间件,10特殊装饰器
一:一个简单知识点
通过路径构成的字符串1、动态导入模块2、找到类,3、字段4、字段的值
import importlib
path = "settings.Foo"
path_item = path.rsplit(".",maxsplit=1)
# 1、通过importlib导入模块
module = importlib.import_module(path_item[0])
#2、通过getattr找到类
cls = getattr(module,path_item[1])
#3、通过dir找到类中的字段
for item in dir(cls):
if item.isupper():
# 4、通过getattr获取字段的值
print(item,getattr(cls,item))
二:配置文件使用
from flask import Flask,render_template,request
app = Flask(__name__,template_folder='templates')
app.config.from_object("settings.Foo")
@app.route("/login",methods=["GET","POST"])
def login():
if request.method == "GET":
return render_template("login.html")
return "ok"
app.run()
settings中内容:
class Base(object):
"""存放共有的内容"""
xx = True class Foo(Base):
DEBUG = True
TEST = True class Dev(Base):
DEBUG = False
三:路由系统
1、endpoint
endpoint相当于Django里面的name,url的别名,用于反向生成url。url_for用于反向生成url。如果装饰器中没有endpoint参数,则默认的endpoint的值为函数名。
from flask import Flask,render_template,request,url_for
@app.route("/login",methods=["GET","POST"],endpoint="login")
def login():
if request.method == "GET":
print(url_for("login"))
return render_template("login.html")
return "ok"
2、url_for
用于反向生成url
3、动态路由
不支持正则,需要用其他的方式实现
使用url_for反向生成动态路由需要往url_for中传递参数
@app.route('/user/<username>')
@app.route('/post/<int:post_id>')
@app.route('/post/<float:post_id>')
@app.route('/post/<path:path>')
@app.route('/login', methods=['GET', 'POST'])
from flask import Flask,render_template,request,url_for
app = Flask(__name__,template_folder='templates')
app.config.from_object("settings.Foo")
@app.route("/login/<int:nid>",methods=["GET","POST"],endpoint="login")
def login(nid):
if request.method == "GET":
print(nid)
print(url_for("login",nid=2))
return render_template("login.html")
return "ok"
app.run()
四、请求相关数据
request.method
request.args
request.form
request.values
request.cookies
request.headers
request.path
request.full_path
request.script_root
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))
五、响应相关数据
return "字符串"
return render_template('html模板路径',**{})
return redirect('/index.html')
from flask import Flask,render_template,request,url_for,jsonify
user_dic = {1:"wang",2:"zhang"}
return jsonify(user_dic)
jsonify相当于在内部做了字符串的序列化,相当于json.dumps
如何响应返回的数据需要加上响应头时,通过make_response实现
response = make_response(render_template('index.html'))
response是flask.wrappers.Response类型
response.delete_cookie('key')
response.set_cookie('key', 'value')
response.headers['X-Something'] = 'A value'
return response
六、模板渲染
1、列表,元组传到前端,前端的表示方式
<li>{{user_list[0]}}</li>
<li>{{user_list[1]}}</li>
<li>{{user_list.0}}</li>
<li>{{user_list.1}}</li>
2、传递需要渲染的字符串
(1)
{{ txt|safe }}
context = {'txt':"<input type='text'/>"}
@app.route("/index",methods=["GET","POST"])
def index():
return render_template("index.html",user_dict = USER_DICT,user_list = USER_LIST,**context)
(2)
context = {'txt':Markup("<input type='text'/>")}
@app.route("/index",methods=["GET","POST"])
def index():
return render_template("index.html",user_dict = USER_DICT,user_list = USER_LIST,**context)
{{ txt }}
3、向前端传入函数
(1)手动自己传
def func():
return "hello"
context = {'txt':Markup("<input type='text'/>"),
'func':func}
@app.route("/index",methods=["GET","POST"])
def index():
return render_template("index.html",user_dict = USER_DICT,user_list = USER_LIST,**context)
{{func}} 表示函数本身
{{func()}} 表示函数的执行
(2)全局传递 @app.template_global() @app.template_filter()
@app.template_global()
def add(a,b):
return a + b
{{add(3,4)}} 不用传递,可以直接在前端写
@app.template_filter()
def add(a,b,c):
return a + b + c
{{1|add(3,4)}} 不用传递,可以直接在前端写
七:session
session在服务器端(程序中)的操作相当于对一个字典进行操作
当请求刚到来时,flask从cookie中获取session对应的值,并反序列化为一个字典放入内存中,以便视图函数进行处理。对它的操作就是增删改查。
@app.route("/s1",methods=["GET"])
def s1():
session["k1"] = "k1"
session["k2"] = "k2"
del session["k1"]
return "ok"
当请求结束时,flask会读取内存中字典的值,进行序列化+加密,写入到用户cookie中。
八、flash
在session中存储的一个数据,读取后通过pop将数据移除,只能取一次数据。
@app.route("/p1",methods=["GET"])
def p1():
flash("临时数据")
return "p1"
@app.route("/p2",methods=["GET"])
def p2():
ret = get_flashed_messages()
print(ret)
return str(ret)
@app.route("/pa1",methods=["GET"])
def pa1():
flash("错误1","err")
flash("错误2","err")
flash("错误3","err")
flash("正确1","right")
flash("正确2","right")
return "ok"
@app.route("/pa2",methods=["GET"])
def pa2():
ret = get_flashed_messages(category_filter=["err"])
print(ret)
return str(ret)
九:中间件
在flask中中间件的使用不是很多,也不是很重要,主要是使用特殊装饰器完成相应的功能。
在接收到请求后才执行请求的__call__方法。
需求:完成一个功能,在执行__call__(一个函数)前执行一个操作,在__call__(一个函数)后执行一个操作。也就是在请求前执行一个操作,在请求后执行一个操作。
class MiddleWare(object):
def __init__(self,old):
self.old = old def __call__(self, *args, **kwargs):
print("wsgi_app执行前执行的操作")
ret = self.old(*args, **kwargs)
print("wsgi_app执行后执行的操作")
return ret app.wsgi_app = MiddleWare(app.wsgi_app)
app.run()
十、特殊装饰器
1. before_request
2. after_request
示例:
from flask import Flask
app = Flask(__name__)
@app.before_request
def x1():
print('before:x1')
return '滚'
@app.before_request
def xx1():
print('before:xx1')
@app.after_request
def x2(response):
print('after:x2')
return response
@app.after_request
def xx2(response):
print('after:xx2')
return response
@app.route('/index')
def index():
print('index')
return "Index"
@app.route('/order')
def order():
print('order')
return "order"
if __name__ == '__main__':
app.run()
3. before_first_request
from flask import Flask
app = Flask(__name__)
@app.before_first_request
def x1():
print('123123')
@app.route('/index')
def index():
print('index')
return "Index"
@app.route('/order')
def order():
print('order')
return "order"
if __name__ == '__main__':
app.run()
4. template_global
5. template_filter
6. errorhandler
@app.errorhandler(404)
def not_found(arg):
print(arg)
return "没找到"
flask基础二的更多相关文章
- flask基础之jijia2模板使用基础(二)
前言 在以前前后端不分离的时代,后台程序员往往又当爹又当妈,需要将前端程序员写的h5页面填充模板语言.而jijia2是一门十分强大的python的模板语言,是flask框架的核心模块之一.先简单介绍一 ...
- flask基础三
一.路由和视图(基础二上补充) (1)有参装饰器 路由采用的是有参装饰器实现的 @app.route("/index",methods=["GET"," ...
- flask基础之AppContext应用上下文和RequestContext请求上下文(六)
前言 应用上下文和请求上下文存在的目的,官方文档讲的很清楚,可参考: http://www.pythondoc.com/flask/appcontext.html 应用上下文对象在没有请求的时候是可以 ...
- flask基础之请求处理核心机制(五)
前言 总结一下flask框架的请求处理流程. 系列文章 flask基础之安装和使用入门(一) flask基础之jijia2模板使用基础(二) flask基础之jijia2模板语言进阶(三) flask ...
- flask基础之app初始化(四)
前言 flask的核心对象是Flask,它定义了flask框架对于http请求的整个处理逻辑.随着服务器被启动,app被创建并初始化,那么具体的过程是这样的呢? 系列文章 flask基础之安装和使用入 ...
- flask基础之jijia2模板语言进阶(三)
前言 前面学习了jijia2模板语言的一些基础知识,接下来继续深挖jijia2语言的用法. 系列文章 flask基础之安装和使用入门(一) flask基础之jijia2模板使用基础(二) 控制语句 和 ...
- Flask基础(14)-->自定义过滤器
Flask基础(13)-->自定义过滤器 什么是过滤器? 过滤器的本质就是函数.有时候我们不仅仅只是需要输出变量的值,我们还需要修改变量的显示,甚至格式化.运算等等,而在模板中是不能直接调用 P ...
- Flask【第2篇】:Flask基础
Flask基础 知识点回顾 1.flask依赖wsgi,实现wsgi的模块:wsgiref,werkzeug,uwsgi 2.实例化Flask对象,里面是有参数的 app = Flask(__name ...
- Python全栈开发【基础二】
Python全栈开发[基础二] 本节内容: Python 运算符(算术运算.比较运算.赋值运算.逻辑运算.成员运算) 基本数据类型(数字.布尔值.字符串.列表.元组.字典) 其他(编码,range,f ...
随机推荐
- JMeter学习笔记02-基础介绍
基本构成 1)负载发生器:产生负载,多线程模拟用户行为 2)用户运行期:脚本运行引擎,用户运行器附加在线程上,根据指定脚本模拟指定的用户行为 3)资源发生器:生成测试过程中服务器.负载机的资源数据 4 ...
- 阿里云OSS 获取目录下所有文件
public class AliyunHandle { public static string accessKeyId = "a1uI5xxxxxxxxxrP4H"; publi ...
- 学习使人快乐5-JavaWeb应用的组成结构
开发JavaWeb应用时,不同类型的文件有严格的存放规则,否则不仅可能会使web应用无法访问,还会导致web服务器启动报错 WebRoot →Web应用所在目录,一般情况下虚拟目录要配置到此文件夹当中 ...
- fillder---断言,更改提交数据
1.before requests:请求的发送前拦截,此时可以修改提交的表单.cookies.header头数据 在URL请求前,设置为before requests 2.after response ...
- xml格式转成json格式,使用Python
import xml.etree.ElementTree root=xml.etree.ElementTree.parse('testXml.xml') book=root.findall('pers ...
- add, subtract, multiply, divide
加.减.乘.除:add, subtract, multiply, divide
- drf序列化组件
rest_framework序列化之Serializer 步骤: 1.自定义一个类,继承Serializer类: 2.在类中写要序列化的字段: 3.使用:在views.py文件中,book_ser=B ...
- 2017-10-22—光电二极管
光通信基本每天都会接触光电二极管,光模块说简单点就是电光转换和光电转换. 光传输模块在整体产品架构上则包括光学次模块(Optical Subassembly;OSA)及电子次模块(Electrical ...
- request请求携带证书,如:微信企业零钱付款
const Promise = require('bluebird') const request = Promise.promisifyAll(require('request')) const w ...
- Windows中杀死占用某个端口的进程(转)
最近写项目,总是出现端口被占用的问题,原来傻傻的把电脑重启一下,终于有一天受不了了,想要想办法解决.刚开始从网上找了好多教程,发现不行.开始自己尝试,终于,成功的将占用端口的进程杀掉.在此记录下过程( ...