使用Flask框架实现 webhook 和 api,并对比区别

实现一个Webhook接收端和一个简单的API端点

Webhook 示例

复制代码
from flask import Flask, request, jsonify

app = Flask(__name__)

@app.route('/webhook', methods=['POST'])
def webhook():
    # 获取请求中的JSON数据
    data = request.json
    
    # 打印接收到的数据
    print(f"Received webhook data: {data}")
    
    # 返回响应
    return jsonify({"status": "success", "message": "Webhook received successfully"}), 200

if __name__ == '__main__':
    app.run(port=5000)

API 示例

复制代码
from flask import Flask, jsonify

app = Flask(__name__)

@app.route('/api/data', methods=['GET'])
def api_data():
    # 定义简单的API数据
    data = {
        "id": 1,
        "name": "Sample Data",
        "description": "This is a sample API response."
    }
    
    # 返回JSON响应
    return jsonify(data), 200

if __name__ == '__main__':
    app.run(port=5001)

对比

  1. 触发机制:

    • Webhook : 被动触发。当某个事件发生时,外部服务会主动向Webhook URL发送请求。在上面的例子中,/webhook路由会在接收到POST请求时处理数据。
    • API : 主动请求。客户端需要通过HTTP请求来获取数据。在API示例中,/api/data路由需要客户端发送GET请求来获取数据。
  2. 数据流向:

    • Webhook : 数据从第三方服务流向我们自己的应用。在Webhook示例中,我们假设某个服务向我们的/webhook端点发送数据。
    • API : 数据从我们的应用流向客户端。在API示例中,客户端请求我们的/api/data端点来获取数据。
  3. 使用场景:

    • Webhook: 适用于需要实时响应某些事件的场景,如支付通知、GitHub事件等。
    • API: 适用于客户端主动请求数据或服务的场景,如获取用户信息、查询数据库等。

如何运行

  1. 确保安装Flask,可以通过以下命令安装:

    复制代码
    pip install Flask
  2. 将Webhook和API示例分别保存为两个Python文件(如webhook_example.pyapi_example.py)。

  3. 启动两个示例,分别监听不同的端口(如5000和5001),然后可以使用工具如Postman测试API和Webhook的功能。

相关推荐
REDcker26 分钟前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
风之所往_1 小时前
Python 3.0 新特性全面总结
python
2401_882273721 小时前
如何在 CSS 中正确加载本地 JPG 背景图片
jvm·数据库·python
Lucas_coding2 小时前
【Claude Code Router】 Claude Code 兼容 OpenAI 格式 API, Claude code 接入本地部署模型
人工智能·python
测试员周周2 小时前
【AI测试系统】第5篇:从 Archon 看 AI 工程化落地:为什么"确定性编排+AI 弹性智能"是终局?
人工智能·python·测试
我命由我123452 小时前
Kotlin 开发 - lateinit 关键字
android·java·开发语言·kotlin·android studio·android-studio·android runtime
Halo_tjn2 小时前
Java Set集合相关知识点
java·开发语言·算法
许彰午2 小时前
我手写了一个 Java 内存数据库(二):B+ 树的插入与分裂
java·开发语言·面试
大飞记Python3 小时前
【2026更新】Python基础学习指南(AI版)——04数据类型
开发语言·人工智能·python
Alice-YUE3 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript