当前位置: 首页 > news >正文

Dify中HTTP请求节点的常见操作

HTTP节点包括API请求类型(GET、POST、HEAD、PATCH、PUT、DELETE),鉴权类型(无、API-Key基础、API-Key Bearer、API-Key自定义),HEADERS键值设置,PARAMS键值设置,BODY(none、form-data、x-www-form-urlencoded、raw text、JSON),超时设置(连接超时、读取超时、写入超时),输出变量(body String 响应内容、status_code Number 响应状态码、headers Object 响应头列表 JSON、files Array[File] 文件列表)。说明:在平时开发中,主要使用GET和POST这两种API请求类型。

一.GET请求类型

功能:查询所有产品。GET请求是获取全部资源。

实现:后端通过Flask实现@app.route('/products', methods=['GET'])

执行Workflow后,在跟踪界面(开始->HTTP请求->结束)可查看最终输出:

二.POST请求类型

功能:创建一个新的产品。POST请求是创建新资源。

实现:后端通过Flask实现@app.route('/products', methods=['POST'])

如果出现status_code: 502,且确保POST接口没有问题,那么基本上是设置了Proxy代理问题,关闭代理接口正常运行。

执行Workflow后,在跟踪界面(开始->HTTP请求->结束)可查看最终输出:

三.HEAD请求类型

功能:根据id检查产品是否存在。HEAD请求为检查资源的存在性。

实现:后端通过Flask实现@app.route('/products/<int:id>', methods=['HEAD'])

执行Workflow后,在跟踪界面(开始->HTTP请求)可查看最终输出:

(1)当使用HEAD方法访问/products/[int:id](int:id)时,函数会检查是否存在具有该ID的产品。

(2)如果产品存在,函数返回状态码200,表示资源存在,但不会返回产品的内容。

(3)如果产品不存在,函数返回状态码404,表示资源不存在。

执行Workflow后,在跟踪界面(开始->HTTP请求->结束)可查看最终输出:

四.PATCH请求类型

功能:根据id更新产品的名字。PATCH请求为部分更新资源。

实现:后端通过Flask实现@app.route('/products/<int:id>', methods=['PATCH'])

执行Workflow后,在跟踪界面(开始->HTTP请求->结束)可查看最终输出:

五.PUT请求类型

功能:替换指定id的产品资源。PUT请求为完全替换资源。

实现:后端通过Flask实现@app.route('/products/<int:id>', methods=['PUT'])

执行Workflow后,在跟踪界面(开始->HTTP请求->结束)可查看最终输出:

核心代码是product.update(request.json)product.update(...) 调用 product 字典的 update 方法,并将 request.json 作为参数传入。这个方法会遍历 request.json 中的所有键值对:

(1)如果 product 中已存在相同的键,则会用 request.json 中的值更新 product 中的值。

(2)如果 product 中不存在对应的键,则会将这个键值对添加到 product 中。

六.DELETE请求类型

功能:删除指定id的产品资源。DELETE请求为删除资源。

实现:后端通过Flask实现@app.route('/products/<int:id>', methods=['DELETE'])

执行Workflow后,在跟踪界面(开始->HTTP请求)可查看最终输出:

七.相关问题

1.API-Key基础、API-Key Bearer、API-Key自定义

API-Key基础: 使用预定义的头字段(如x-api-key)传递API密钥,简单直接。API-Key Bearer: 使用OAuth风格的Bearer Token传递API密钥,更适合需要增强安全性的场景。API-Key自定义: 根据需求自定义API密钥的传递方式,提供更大的灵活性。

(1)API-Key基础

API Key 基础认证是一种简单的认证方式,客户端在请求时将API密钥作为请求的一部分进行传递。通常,它会在请求头中包含一个特定的字段来传递API密钥。示例如下:

GET /resource HTTP/1.1
Host: api.example.com
x-api-key: your_api_key_here

(2)API-Key Bearer

API Key Bearer认证方式类似于使用OAuth的Bearer Token。客户端在请求头中的Authorization字段中传递API密钥,并以"Bearer"作为前缀。这种方式常用于需要更高安全性的场景。示例如下:

GET /resource HTTP/1.1
Host: api.example.com
Authorization: Bearer your_api_key_here

(3)API-Key自定义

API Key自定义认证允许开发人员根据需求自定义API密钥的传递方式。可以将API密钥放在请求的查询参数、请求体中,或者在请求头中使用自定义字段名。这种方式的灵活性较高,但需要确保在客户端和服务器端一致使用同样的方式。

查询参数方式,示例如下:

GET /resource?api_key=your_api_key_here HTTP/1.1
Host: api.example.com

请求体方式,示例如下:

POST /resource HTTP/1.1
Host: api.example.com
Content-Type: application/json{"api_key": "your_api_key_here","other_data": "value"
}

自定义头字段方式,示例如下:

GET /resource HTTP/1.1
Host: api.example.com
x-custom-api-key: your_api_key_here
2.POST和PUT请求异同

(1)幂等性:POST不是幂等的,而PUT是幂等的。

(2)用途:POST用于创建,PUT用于更新或替换。

(3)URI的知晓:使用POST时,通常不知道新资源的URI;使用PUT时,通常知道资源的URI。

3.form-data和x-www-form-urlencoded异同

当需要上传文件时,应选择 form-data;如果仅需要提交简单的文本表单,x-www-form-urlencoded 是一个更简洁的选择。

(1)form-data 通常用于文件上传或当表单包含文本和文件数据时使用。

(2)x-www-form-urlencoded 通常用于简单的表单提交,当数据仅包含文本内容时使用。

参考文献

[1] HTTP请求:https://docs.dify.ai/v/zh-hans/guides/workflow/node/http_request

NLP工程化(星球号)

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 数据url
  • C++中 cin、cin.get()、cin.getline()、getline() 的区别
  • Blender材质-PBR与纹理材质
  • scratch聊天机器人 2024年6月scratch四级 中国电子学会图形化编程 少儿编程等级考试四级真题和答案解析
  • sql server 连接报错error 40
  • 基于内容的音乐推荐网站/基于ssm的音乐推荐系统/基于协同过滤推荐的音乐网站/基于vue的音乐平台
  • 基于Element UI内置的Select下拉和Tree树形组件,组合封装的树状下拉选择器
  • 这一文,关于 Java 泛型的点点滴滴 一(泛型基础、类型擦除)
  • Javascript面试基础6【每日更新10】
  • MyBatis中的赋值语句:#{}和${}的区别差异(常见面试题)
  • 【Python机器学习】决策树的构造——划分数据集
  • 2024最新Uniapp的H5网页版添加谷歌授权验证
  • linux进程——解析命令行参数——环境变量详解
  • Spring Security面试三道题
  • 查找算法-二分查找(折半查找)
  • [译]前端离线指南(上)
  • 【Leetcode】104. 二叉树的最大深度
  • 【前端学习】-粗谈选择器
  • 07.Android之多媒体问题
  • 30天自制操作系统-2
  • download使用浅析
  • hadoop入门学习教程--DKHadoop完整安装步骤
  • java中的hashCode
  • Laravel 实践之路: 数据库迁移与数据填充
  • miniui datagrid 的客户端分页解决方案 - CS结合
  • MyEclipse 8.0 GA 搭建 Struts2 + Spring2 + Hibernate3 (测试)
  • windows下使用nginx调试简介
  • 不用申请服务号就可以开发微信支付/支付宝/QQ钱包支付!附:直接可用的代码+demo...
  • 关于springcloud Gateway中的限流
  • 聚簇索引和非聚簇索引
  • 利用阿里云 OSS 搭建私有 Docker 仓库
  • 再次简单明了总结flex布局,一看就懂...
  • hi-nginx-1.3.4编译安装
  • 阿里云移动端播放器高级功能介绍
  • ​Distil-Whisper:比Whisper快6倍,体积小50%的语音识别模型
  • (14)Hive调优——合并小文件
  • (delphi11最新学习资料) Object Pascal 学习笔记---第13章第1节 (全局数据、栈和堆)
  • (poj1.3.2)1791(构造法模拟)
  • (Redis使用系列) Springboot 使用Redis+Session实现Session共享 ,简单的单点登录 五
  • (SpringBoot)第二章:Spring创建和使用
  • (二)Pytorch快速搭建神经网络模型实现气温预测回归(代码+详细注解)
  • (二)springcloud实战之config配置中心
  • (二)斐波那契Fabonacci函数
  • (附源码)SSM环卫人员管理平台 计算机毕设36412
  • (十六)串口UART
  • (小白学Java)Java简介和基本配置
  • (一)appium-desktop定位元素原理
  • (转载)利用webkit抓取动态网页和链接
  • *(长期更新)软考网络工程师学习笔记——Section 22 无线局域网
  • .gitignore文件—git忽略文件
  • .NET Core/Framework 创建委托以大幅度提高反射调用的性能
  • .Net Web窗口页属性
  • @Autowired标签与 @Resource标签 的区别
  • @RequestBody的使用
  • [ 隧道技术 ] 反弹shell的集中常见方式(二)bash反弹shell