内容有: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基础二的更多相关文章

  1. flask基础之jijia2模板使用基础(二)

    前言 在以前前后端不分离的时代,后台程序员往往又当爹又当妈,需要将前端程序员写的h5页面填充模板语言.而jijia2是一门十分强大的python的模板语言,是flask框架的核心模块之一.先简单介绍一 ...

  2. flask基础三

    一.路由和视图(基础二上补充) (1)有参装饰器 路由采用的是有参装饰器实现的 @app.route("/index",methods=["GET"," ...

  3. flask基础之AppContext应用上下文和RequestContext请求上下文(六)

    前言 应用上下文和请求上下文存在的目的,官方文档讲的很清楚,可参考: http://www.pythondoc.com/flask/appcontext.html 应用上下文对象在没有请求的时候是可以 ...

  4. flask基础之请求处理核心机制(五)

    前言 总结一下flask框架的请求处理流程. 系列文章 flask基础之安装和使用入门(一) flask基础之jijia2模板使用基础(二) flask基础之jijia2模板语言进阶(三) flask ...

  5. flask基础之app初始化(四)

    前言 flask的核心对象是Flask,它定义了flask框架对于http请求的整个处理逻辑.随着服务器被启动,app被创建并初始化,那么具体的过程是这样的呢? 系列文章 flask基础之安装和使用入 ...

  6. flask基础之jijia2模板语言进阶(三)

    前言 前面学习了jijia2模板语言的一些基础知识,接下来继续深挖jijia2语言的用法. 系列文章 flask基础之安装和使用入门(一) flask基础之jijia2模板使用基础(二) 控制语句 和 ...

  7. Flask基础(14)-->自定义过滤器

    Flask基础(13)-->自定义过滤器 什么是过滤器? 过滤器的本质就是函数.有时候我们不仅仅只是需要输出变量的值,我们还需要修改变量的显示,甚至格式化.运算等等,而在模板中是不能直接调用 P ...

  8. Flask【第2篇】:Flask基础

    Flask基础 知识点回顾 1.flask依赖wsgi,实现wsgi的模块:wsgiref,werkzeug,uwsgi 2.实例化Flask对象,里面是有参数的 app = Flask(__name ...

  9. Python全栈开发【基础二】

    Python全栈开发[基础二] 本节内容: Python 运算符(算术运算.比较运算.赋值运算.逻辑运算.成员运算) 基本数据类型(数字.布尔值.字符串.列表.元组.字典) 其他(编码,range,f ...

随机推荐

  1. python开发遇到的坑(1)xpath解析ValueError: Unicode strings with encoding declaration are not supported

    Traceback (most recent call last): File "/Users/*******.py", line 37, in <module> Bt ...

  2. Idea 问题记录

    日常问题记录 下载IDEA, tomcat ,下载jdk 前言:java net对比 Java:JDK  .NET:.NetFramework WEB服务器 Java:Tomcat,JBoss,Web ...

  3. 【easy】111. Minimum Depth of Binary Tree求二叉树的最小深度

    求二叉树的最小深度: /** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; ...

  4. powerdesigner添加mysql的字符集支持

    一般建模可能都会用到:powerdesigner 但是,在建表的时候,我一直没有找到: DEFAULT CHARACTER SET COLLATE 两个选项.因此,想了个方法,点击:工具栏->d ...

  5. 解决jenkins构建job报错“NoClassDefFoundError” in jenkins/scm/RunWithSCM问题

    现象 使用Jenkins 2.8,当我运行一个简单的Jenkins工作时,构建一个job获取源代码,出现下面的错误 FATAL: jenkins/scm/RunWithSCM java.lang.No ...

  6. java基础学习总结——面向对象1

    目录 一.面向过程的思想和面向对象的思想 二.简单理解面向对象 三.面向对象的设计思想 四.对象和类的概念 五.如何抽象出一个类? 六.类(对象)之间的关系 七.Java与面向对象 八.为什么使用面向 ...

  7. MongoDB 及 scrapy 应用

    0 1.Scrapy 使用 MongoDB https://doc.scrapy.org/en/latest/topics/item-pipeline.html#write-items-to-mong ...

  8. Dapper官方库 在guid和string互转的问题

    之前在和老何谈论他的开源项目Util中使用MySql的过程中发现了官方dapper在转换guid到string时候的一个错误 Error parsing column 0 (ID=6c2adb93-d ...

  9. ionic2自定义radio样式

    刚开始以为用的是字体图标,结果翻了代码一看竟然是通过纯css实现的,图标模式用的是ios,代码如下: .radio-ios .radio-checked { margin:; border-radiu ...

  10. 关于ajax请求数据,并将数据赋值给全局变量的一些解决方法

    在使用ajax请求数据是,开始的时候是打算将ajax的数据取出,并赋予给全局变量,但是在实际编码过程中发现并不能将数据赋予给最开始定义的全局变量,出现这个问题的原因是由于ajax异步加载的原因,所以只 ...