Flask Web API构建实例:GET、POST文件上传、静态资源下载一网打尽

发布时间 2023-12-27 07:46:08作者: 架构师老卢

 

以下是一个通过 Flask 构建 Web API 服务的详细示例,包含了各类请求(GET、POST、文件上传、静态资源下载)、每个方法独立配置路由、参数接收和解析、请求日志记录以及异常日志记录。请确保你已经安装了 Flask,你可以使用以下命令进行安装:

pip install Flask

接下来是一个包含详细注释的源代码示例:

from flask import Flask, request, send_from_directory
import logging

app = Flask(__name__)

# 配置日志
logging.basicConfig(filename='api.log', level=logging.DEBUG, format='%(asctime)s [%(levelname)s] - %(message)s')

# 定义路由和资源
@app.route('/hello', methods=['GET', 'POST'])
def hello_world():
    if request.method == 'GET':
        # 记录请求日志
        logging.info('GET 请求收到')
        return {'message': '你好,世界!'}
    elif request.method == 'POST':
        # 获取请求中的参数
        data = request.get_json()

        # 记录请求日志
        logging.info(f'POST 请求收到,数据:{data}')

        # 模拟处理数据
        try:
            result = data['input'] * 2
            return {'result': result}
        except KeyError as e:
            # 记录异常日志
            logging.error(f'请求数据中缺少键: {e}')
            return {'error': '无效的请求数据'}, 400

# 文件上传
@app.route('/upload', methods=['POST'])
def upload_file():
    # 获取上传的文件
    file = request.files['file']

    # 记录请求日志
    logging.info(f'文件上传请求收到: {file.filename}')

    # 保存文件到服务器
    file.save(f'uploads/{file.filename}')

    return {'message': '文件上传成功'}

# 静态资源下载
@app.route('/static/<path:filename>')
def serve_static(filename):
    return send_from_directory('static', filename)

# 启动应用
if __name__ == '__main__':
    app.run(debug=True)

在这个例子中:

  • /hello 路由包含了 GET 和 POST 方法,演示了如何获取请求中的参数,并记录请求日志和异常日志。
  • /upload 路由处理了文件上传请求,将文件保存到服务器的 uploads 目录中,并记录请求日志。
  • /static/<path:filename> 路由配置用于提供静态资源下载。

你可以通过以下方式进行测试:

  • GET 请求:http://127.0.0.1:5000/hello
  • POST 请求:http://127.0.0.1:5000/hello,请求体为 JSON 格式的数据。
  • 文件上传:使用 POST 请求 http://127.0.0.1:5000/upload,并在请求中添加一个文件。
  • 静态资源下载:http://127.0.0.1:5000/static/example.txt(示例文件名)。

运行这个脚本后,你可以在浏览器或工具中查看返回的数据,并在脚本所在目录下的 api.log 文件中找到日志记录。这个示例提供了一个基本框架,你可以根据实际需求扩展和修改。