URL路径参数
转换器
from flask import Flask app =Flask(__name__) #/user/123 @app.route('/user/<int:user_id>')#int:规定只能输入该类型字符 并自动帮你转成该类型 def get_user_id(user_id): return 'get users {}.'.format(user_id) if __name__ == '__main__': app.run()
Flask也提供其他类型的转换器
DEFAULT_CONVERTERS = {
'default': UnicodeConverter,
'string': UnicodeConverter,
'any': AnyConverter,
'path': PathConverter,
'int': IntegerConverter,
'float': FloatConverter,
'uuid': UUIDConverter,
}
自定义转化器
from flask import Flask from werkzeug.routing import BaseConverter #自定义转化器 class Mobile(BaseConverter): regex = r'1[1-9]d{9}' #创建应用 app =Flask(__name__) #将自定义转换器添加到转换器字典中,并指定转化器使用名字为: mobile app.url_map.converters['mobile'] = Mobile #/user/123 @app.route('/user/<mobile:user_id>')#int:规定只能输入该类型字符 并自动帮你转成该类型 def get_user_id(user_id): return 'get users {}.'.format(user_id) if __name__ == '__main__': app.run()
flask的request
flask的request
不同位置的参数都存放在request的不同属性中
属性 | 说明 | 类型 |
---|---|---|
data | 记录请求的数据,并转换为字符串 | * |
form | 记录请求中的表单数据 | MultiDict |
args | 记录请求中的查询参数 | MultiDict |
cookies | 记录请求中的cookie信息 | Dict |
headers | 记录请求中的报文头 | EnvironHeaders |
method | 记录请求使用的HTTP方法 | GET/POST |
url | 记录请求的URL地址 | string |
files | 记录请求上传的文件 | * |
例如 想要获取请求/articles?channel_id=1
中channel_id
的参数,可以按如下方式使用:
from flask import request @app.route('/articles') def get_articles(): channel_id = request.args.get('channel_id') return 'you wanna get articles of channel {}'.format(channel_id)
处理响应
#响应处理 from flask import Flask,render_template #导入渲染模板的类 app = Flask(__name__) @app.route('/') def home(): str = '我草' int = 123 content = dict( my_str ='你妈', my_int = 456 ) # return render_template('index.html',my_str =str,my_int = int) #第一种渲染方式 return render_template('index.html', **content) #第二种渲染方式 content里的变量名必须与模板中的一致 if __name__ == '__main__': app.run()
重定向
from flask import redirect @app.route('/demo2') def demo2(): return redirect('http://www.itheima.com')
返回json
from flask import jsonify @app.route('/demo3') def demo3(): json_dict = { "user_id": 10, "user_name": "laowang" } return jsonify(json_dict)
自定义状态码和响应头
1 元祖方式
可以返回一个元组,这样的元组必须是(response,status,headers)的形式,并且至少包含一个元素。status值会覆盖状态代码,headers可以是一个列表或字典,作为额外的消息标头值。
@app.route('/demo4') def demo4(): # return '状态码为 666', 666 # return '状态码为 666', 666, [('Itcast', 'Python')] return '状态码为 666', 666, {'Itcast': 'Python'}
2 make_response方式
@app.route('/demo5') def demo5(): resp = make_response('make response测试') resp.headers[“Itcast”] = “Python” resp.status = “404 not found” return resp
cookie
设置
@app.route('/cookie') def set_cookie(): response = make_response('hello world')#只能用make构造返回 因为后续还要设置cookie 如果直接return响应 就不能设置cookie response.set_cookie('username', 'itheima', max_age=3600) return response
读取
from flask import request @app.route('/get_cookie') def get_cookie(): resp = request.cookies.get('username') return resp
删除
from flask import request @app.route('/delete_cookie') def delete_cookie(): response = make_response('hello world') response.delete_cookie('username') return response
Session
flask把session存在浏览器上 但是是经过服务器的secret_key签名的
需要先设置SECRET_KEY
class DefaultConfig(object): SECRET_KEY = 'fih9fh9eh9gh2' app.config.from_object(DefaultConfig) 或者直接设置 app.secret_key='xihwidfw9efw'
设置session
from flask import session @app.route('/set_session') def set_session(): session['username'] = 'itcast' return 'set session ok'
读取
@app.route('/get_session') def get_session(): username = session.get('username') return 'get session username {}'.format(username)
异常处理
- 方法
- 抛出一个给定状态代码的HTTPException或指定响应,例如想要用一个页面未找到异常来终止请求,你可以调用abort(404)。
- 参数:
- 代码– HTTP的错误状态码
# abort(404)
abort(500)
- 捕获指定异常
@app.errorhandler(ZeroDivisionError) def zero_division_error(e): return '除数不能为0'
请求钩子
在客户端和服务器交互的过程中,有些准备工作或扫尾工作需要处理,比如:
- 在请求开始时,建立数据库连接;
- 在请求开始时,根据需求进行权限校验;
- 在请求结束时,指定数据的交互格式;
为了让每个视图函数避免编写重复功能的代码,Flask提供了通用设施的功能,即请求钩子。
请求钩子是通过装饰器的形式实现,Flask支持如下四种请求钩子:
- before_first_request
- 在处理第一个请求前执行
- before_request
- 在每次请求前执行
- 如果在某修饰的函数中返回了一个响应,视图函数将不再被调用
- after_request
- 如果没有抛出错误,在每次请求后执行
- 接受一个参数:视图函数作出的响应
- 在此函数中可以对响应值在返回之前做最后一步修改处理
- 需要将参数中的响应在此参数中进行返回
- teardown_request:
- 在每次请求后执行
- 接受一个参数:错误信息,如果有相关错误抛出
from flask import Flask from flask import abort app = Flask(__name__) # 在第一次请求之前调用,可以在此方法内部做一些初始化操作 @app.before_first_request def before_first_request(): print("before_first_request") # 在每一次请求之前调用,这时候已经有请求了,可能在这个方法里面做请求的校验 # 如果请求的校验不成功,可以直接在此方法中进行响应,直接return之后那么就不会执行视图函数 @app.before_request def before_request(): print("before_request") # if 请求不符合条件: # return "laowang" # 在执行完视图函数之后会调用,并且会把视图函数所生成的响应传入,可以在此方法中对响应做最后一步统一的处理 @app.after_request def after_request(response): print("after_request") response.headers["Content-Type"] = "application/json" return response # 请每一次请求之后都会调用,会接受一个参数,参数是服务器出现的错误信息 @app.teardown_request def teardown_request(e): print("teardown_request") @app.route('/') def index(): return 'index' if __name__ == '__main__': app.run(debug=True)
上下文(上下文实现原理:threadlocal--线程局部变量)
上下文:即语境,语意,在程序中可以理解为在代码执行到某一时刻时,根据之前代码所做的操作以及下文即将要执行的逻辑,可以决定在当前时刻下可以使用到的变量,或者可以完成的事情。
Flask中有两种上下文,请求上下文和应用上下文
Flask中上下文对象:相当于一个容器,保存了 Flask 程序运行过程中的一些信息。
请求上下文(request context)
思考:在视图函数中,如何取到当前请求的相关数据?比如:请求地址,请求方式,cookie等等
在 flask 中,可以直接在视图函数中使用 request 这个对象进行获取相关数据,而 request 就是请求上下文的对象,保存了当前本次请求的相关数据,请求上下文对象有:request、session
- request
- 封装了HTTP请求的内容,针对的是http请求。举例:user = request.args.get('user'),获取的是get请求的参数。
- session
- 用来记录请求会话中的信息,针对的是用户信息。举例:session['name'] = user.id,可以记录用户信息。还可以通过session.get('name')获取用户信息。
应用上下文(application context)
它的字面意思是 应用上下文,但它不是一直存在的,它只是request context 中的一个对 app 的代理(人),所谓local proxy。它的作用主要是帮助 request 获取当前的应用,它是伴 request 而生,随 request 而灭的。
应用上下文对象有:current_app,g
current_app(在蓝图里使用全局变量)
应用程序上下文,用于存储应用程序中的变量,可以通过current_app.name打印当前app的名称,也可以在current_app中存储一些变量,例如:
- 应用的启动脚本是哪个文件,启动时指定了哪些参数
- 加载了哪些配置文件,导入了哪些配置
- 连了哪个数据库
- 有哪些public的工具类、常量
- 应用跑再哪个机器上,IP多少,内存多大
g变量(仅在一次请求中有效)
g 作为 flask 程序全局的一个临时变量,充当者中间媒介的作用,我们可以通过它传递一些数据,g 保存的是当前请求的全局变量,不同的请求会有不同的全局变量,通过不同的thread id区别