响应(Response)

发布于:2025-03-15 ⋅ 阅读:(15) ⋅ 点赞:(0)

在 Flask 中,视图函数可以返回多种类型的响应,例如字符串、HTML、JSON、文件等。Flask 提供了 make_response 函数,用于生成和自定义 HTTP 响应。

2.1 默认响应

默认情况下,视图函数返回的字符串会被 Flask 包装成一个 HTTP 响应,状态码为 200 OK,内容类型为 text/html

@app.route('/')
def home():
    return "Hello, World!"  # 默认状态码为 200,内容类型为 text/html

2.2 使用 make_response 自定义响应

make_response 函数允许你自定义响应的状态码、头部、内容类型等。

2.2.1 基本用法
from flask import Flask, make_response

app = Flask(__name__)

@app.route('/custom')
def custom_response():
    response = make_response("This is a custom response", 201)  # 状态码为 201
    response.headers['Content-Type'] = 'text/plain'
    return response
  • make_response 的第一个参数是响应内容,第二个参数是状态码。

  • 可以通过 response.headers 设置响应头部。

2.2.2 设置 Cookies
@app.route('/set-cookie')
def set_cookie():
    response = make_response("Cookie set!")
    response.set_cookie('username', 'john')
    return response
  • set_cookie 方法用于设置 Cookie。

2.2.3 返回 JSON 数据

python

复制

from flask import jsonify

@app.route('/json')
def json_response():
    data = {'name': 'John', 'age': 30}
    return jsonify(data)  # 返回 JSON 格式的响应
  • jsonify 函数会将 Python 字典转换为 JSON 格式的响应。

2.2.4 返回文件
from flask import send_file

@app.route('/download')
def download_file():
    return send_file('path/to/file.txt', as_attachment=True)
  • send_file 函数用于发送文件,as_attachment=True 表示文件作为附件下载。


3. 请求和响应的完整示例

以下是一个完整的示例,展示如何处理请求和生成响应:

python

复制

from flask import Flask, request, make_response, jsonify

app = Flask(__name__)

@app.route('/greet', methods=['GET', 'POST'])
def greet():
    if request.method == 'GET':
        name = request.args.get('name', 'Guest')
    elif request.method == 'POST':
        name = request.form.get('name', 'Guest')

    response = make_response(f"Hello, {name}!", 200)
    response.set_cookie('username', name)
    return response

@app.route('/api/data')
def api_data():
    data = {'status': 'success', 'message': 'Hello, World!'}
    return jsonify(data)

if __name__ == '__main__':
    app.run(debug=True)
  • 访问 /greet?name=John 会返回 "Hello, John!",并设置一个名为 username 的 Cookie。

  • 访问 /api/data 会返回 JSON 格式的响应。


网站公告

今日签到

点亮在社区的每一天
去签到