在Flask框架中,视图函数返回响应有四种常见方式,都得掌握。
一、返回文本内容
可以直接返回字符串,Flask会自动将其转换为一个响应对象,具有默认的text/html
内容类型。
@app.route('/return_text')
def return_text():return "这是一段文本数据"
二、返回JSON格式内容
使用jsonify
函数(前后端分离),它是Flask提供的辅助函数,专门用于将Python字典或其他可序列化对象转换为JSON响应。
from flask import jsonify@app.route('/return_json')
def return_json():data = {"name": "xiaodai", "age": 18}return jsonify(data)
三、返回自定义的Response对象
在Flask中,可以直接实例化一个Response
对象来更精细地控制响应的内容、状态码以及头部信息。
from flask import Response@app.route('/custom_response')
def custom_response():# 创建一个自定义的响应内容custom_content = "这是自定义的响应内容"# 实例化一个Response对象response = Response(response=custom_content, # 响应内容status=200, # HTTP状态码,默认是200 OKmimetype='text/plain', # 响应的MIME类型,默认为'text/html'headers={ # 自定义响应头'X-Custom-Header': 'Some Value'})return response
返回JSON内容还能和Response对象一起使用,只需将jsonify()返回的值用get_data()取出来传给response参数就行。
@app.route('/api/data', methods=['GET'])
def get_data():data = {"message": "Hello from the API","status": "success"}# 使用jsonify来创建标准的JSON响应内容,然后包装到自定义的Response中json_response = jsonify(data)# 转换为Response对象以添加自定义头部response = Response(response=json_response.get_data(), # 获取jsonify生成的字节流数据status=200,mimetype='application/json', # 指定为JSON类型headers={'X-API-Version': '1.0' # 自定义响应头})return response
四、渲染模版并返回数据
使用render_template
函数(前后端不分离),它会加载指定的HTML模板文件,并且可以传递字典参数给模板以便填充动态内容。
from flask import render_template@app.route('/')
def index():username = "小呆"return render_template('index.html', username=username)
还可以先使用render_template
函数渲染模板得到HTML内容,然后将这个内容传入Response
的构造函数中,创建一个自定义的Response
对象。这样,你可以在保留模板渲染功能的同时,进一步自定义响应的其他方面。
from flask import render_template, Response@app.route('/custom-rendered-template')
def custom_rendered_template():# 使用render_template渲染模板rendered_template = render_template('example.html')# 将渲染结果包装进自定义的Response对象中response = Response(response=rendered_template, # 渲染后的模板内容status=200, # 可以根据需要修改状态码mimetype='text/html', # 默认情况下,render_template生成的是HTML内容,所以这里保持'text/html'headers={ # 添加任何自定义的响应头'X-Custom-Header': 'Custom Value'})return response