Kimi实战1/100 - 读接口文档,编写接口
文章目录
- Kimi实战1/100 - 读接口文档,编写接口
- 接口调用
- requests 调用代码
- 说明
- 注意事项
- 接口提供
- FastAPI 接口代码
- 代码说明
- 测试方法
Kimi实战1/100 - 读接口文档,编写接口
接口调用
User: 根据 接口文档 https://www.eiisys.com/home/apiDetails?id=00300000280
编写 requests 调用
Kimi: 根据提供的接口文档,可以使用 Python 的 requests 库来调用该接口。以下是一个示例代码,用于获取 53kf_token:
requests 调用代码
import requests
import time
import json# 定义请求的URL
url = "https://appidmanager.53kf.com/appid/manager/get/token"# 获取当前时间戳(秒级)
timestamp = int(time.time())# 定义headers参数
headers = {"timestamp": str(timestamp),"Content-Type": "application/json"
}# 定义body参数(需要替换为实际的appid和appsecret)
body = {"cmd": "53kf_token","appid": "your_appid", # 替换为实际的appid"appsecret": "your_appsecret" # 替换为实际的appsecret
}# 发送POST请求
response = requests.post(url, headers=headers, data=json.dumps(body))# 获取响应内容
response_data = response.json()# 打印响应结果
print("响应状态码:", response_data.get("code"))
print("响应数据:", response_data)# 根据返回的状态码处理结果
if response_data.get("code") == 200:token = response_data.get("data", {}).get("53kf_token")print("获取的53kf_token:", token)print("Token有效期:", response_data.get("data", {}).get("expires_in"), "秒")
else:print("调用失败,错误信息:", response_data.get("msg"))
说明
- 时间戳:
timestamp是请求头中的必选参数,用于验证请求是否过期。代码中使用time.time()获取当前时间戳(秒级)。 - appid 和 appsecret:需要替换为实际的值,这些值可以在客服系统后台、账号管家后台或服务商后台中查看。
- Content-Type:请求头中需要指定
Content-Type为application/json,因为接口要求以 JSON 格式发送数据。 - 错误处理:根据返回的状态码(
code)判断调用是否成功,并打印相应的信息。
注意事项
- 如果返回状态码为
401,可能是时间戳过期或缺失。确保时间戳是当前时间,并且请求在10秒内完成。 - 如果返回状态码为
102,可能是appid或appsecret参数错误,请检查参数是否正确。 - 在实际使用中,建议对
appid和appsecret进行加密处理,以防止泄露。
接口提供
User: 根据接口文档 https://www.eiisys.com/home/apiDetails?id=00300000245
编写对应的fastapi接口
Kimi: 根据提供的接口文档,我们可以使用 FastAPI 框架编写一个对应的接口来接收海翕云的通话记录推送。以下是实现代码:
FastAPI 接口代码
from fastapi import FastAPI, Request, HTTPException
from pydantic import BaseModel
from typing import List, Optional
import json
import urllib.parseapp = FastAPI()# 定义请求体的模型
class CallRecord(BaseModel):cmd: strcompany_id: strphone: strcall: strstart_time: strend_time: strlast_time: strendtype: strtalk_page: Optional[str] = Noneland_page: Optional[str] = Nonereferer: Optional[str] = Nonese: Optional[str] = Nonekw: Optional[str] = Noneworker_id: Optional[str] = Nonecall_id: strcome_out: strrecordurl: Optional[str] = Nonethird_id: Optional[str] = Noneout_robot_guest_name: Optional[str] = Noneout_robot_record: Optional[List[dict]] = None# 定义回调接口
@app.post("/callback")
async def callback(request: Request):form_data = await request.form()msg_id = form_data.get("msg_id")content = form_data.get("content")if not msg_id or not content:raise HTTPException(status_code=400, detail="Missing msg_id or content")try:# 解码 content 数据decoded_content = urllib.parse.unquote(content)call_record = json.loads(decoded_content)call_record_model = CallRecord(**call_record)except json.JSONDecodeError:raise HTTPException(status_code=400, detail="Invalid JSON format")# 处理通话记录数据print(f"Received call record with msg_id: {msg_id}")print(call_record_model)# 返回确认响应return {"cmd": "OK", "token": "YOUR_TOKEN_HERE"}if __name__ == "__main__":import uvicornuvicorn.run(app, host="0.0.0.0", port=8000)
代码说明
-
请求体模型:
- 使用 Pydantic 的
BaseModel定义了CallRecord模型,对应文档中的 JSON 数据结构。 - 其中部分字段是可选的(
Optional),例如talk_page、referer等。
- 使用 Pydantic 的
-
回调接口:
- 使用
@app.post("/callback")定义了一个 POST 接口,用于接收海翕云的推送。 - 从请求中提取
msg_id和content数据。 - 使用
urllib.parse.unquote对content进行解码,并将其解析为 JSON 数据。 - 将解析后的数据加载到
CallRecord模型中,进行数据校验。
- 使用
-
返回确认响应:
- 根据文档要求,返回
{"cmd": "OK", "token": "YOUR_TOKEN_HERE"},其中YOUR_TOKEN_HERE需要替换为实际的令牌。
- 根据文档要求,返回
-
运行方式:
- 使用
uvicorn作为 ASGI 服务器运行 FastAPI 应用。 - 默认监听
0.0.0.0:8000,可以根据需要修改端口。
- 使用
测试方法
-
启动 FastAPI 应用:
uvicorn main:app --reload其中
main是文件名,app是 FastAPI 实例的名称。 -
发送测试请求:
使用curl或 Postman 发送 POST 请求到http://127.0.0.1:8000/callback,请求体为表单数据:curl -X POST "http://127.0.0.1:8000/callback" \-F "msg_id=ee505c81-3f29-4cb4-abdf-d0bb846fab9e" \-F "content=%7B%22cmd%22%3A%22callback_phone%22%2C%22company_id%22%3A%2272000370%22%2C%22phone%22%3A%2217357927020%22%2C%22call%22%3A%2218158360535%22%2C%22start_time%22%3A%222021-06-28+15%3A45%3A46%22%2C%22end_time%22%3A%222021-06-28+15%3A45%3A59%22%2C%22last_time%22%3A%222%22%2C%22endtype%22%3A%222%22%2C%22call_id%22%3A%2216374%22%2C%22recordurl%22%3A%22https%3A%5C%2F%5C%2Ffs.53kf.com%5C%2Frecordings%5C%2F2021-06-28%5C%2F7573bba2-6b21-4a07-8995-1cab4875a7a4.wav%22%7D" -
检查输出:
- 确保 FastAPI 接口能够正确接收并解析数据,并返回确认响应。
如果需要进一步处理通话记录数据(例如存储到数据库或触发其他逻辑),可以在 callback 函数中添加相应的代码逻辑。
相关文章:
Kimi实战1/100 - 读接口文档,编写接口
文章目录 Kimi实战1/100 - 读接口文档,编写接口接口调用requests 调用代码说明注意事项 接口提供FastAPI 接口代码代码说明测试方法 Kimi实战1/100 - 读接口文档,编写接口 接口调用 User: 根据 接口文档 https://www.eiisys.com/home/apiDetails?id00…...
Spring Cache @Cacheable:提升应用性能的利器
在构建企业级应用时,性能优化至关重要。Spring Cache 提供了一种简便而强大的方式来缓存方法调用的结果,从而减少数据库访问、提高响应速度。其中,Cacheable 注解是 Spring Cache 的核心,本文将深入剖析 Cacheable 注解࿰…...
css块级元素和行内元素区别
在CSS中,元素可以分为两大类:块级元素(Block-level elements)和行内元素(Inline elements)。这两种元素在网页布局中起着不同的作用,主要体现在它们的显示方式、尺寸控制、以及与其他元素的交互…...
AWTK fscript 中的 TCP/UDP 客户端扩展函数
fscript 是 AWTK 内置的脚本引擎,开发者可以在 UI XML 文件中直接嵌入 fscript 脚本,提高开发效率。本文介绍一下 fscript 中的 TCP/UDP 客户端扩展函数。 1.iostream_tcp_create 创建 TCP 客户端输入输出流对象。 原型 iostream_tcp_create(host, por…...
[免费]Springboot+Vue医疗(医院)挂号管理系统【论文+源码+SQL脚本】
大家好,我是java1234_小锋老师,看到一个不错的SpringbootVue医疗(医院)挂号管理系统,分享下哈。 项目视频演示 【免费】SpringBootVue医疗(医院)挂号管理系统 Java毕业设计_哔哩哔哩_bilibili 项目介绍 在如今社会上,关于信息上…...
计算机毕业设计PySpark+hive招聘推荐系统 职位用户画像推荐系统 招聘数据分析 招聘爬虫 数据仓库 Django Vue.js Hadoop
温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…...
Jmeter+Influxdb+Grafana平台监控性能测试过程
一、Jmeter自带插件监控 下载地址:https://jmeter-plugins.org/install/Install/ 安装:下载后文件为jmeter-plugins-manager-1.3.jar,将其放入jmeter安装目录下的lib/ext目录,然后重启jmeter,即可。 启动Jmeter&…...
fatal: unable to access ‘https://github.com/xxx/‘: SSL peer certificat
从github上clone代码时报错 F:\Projects>git clone https://github.com/xxx into xxx... fatal: unable to access https://github.com/xxx/: SSL peer certificate or SSH remote key was not OK **可能的原因****解决方法****1. 检查系统时间****2. 禁用 SSL 验证…...
Prompt通用技巧
Prompt 的典型构成 角色:给 AI定义一个最匹配任务的角色,比如:「你是一位软件工程师」「你是一位小学老师」指示:对任务进行描述上下文: 给出与任务相关的其它背景信息(尤其在多轮交互中)。例子 : 必要时给出举例,学术中称为 one-shot learning,few-sho…...
ROACH
End-to-End Urban Driving by Imitating a Reinforcement Learning Coach CARLA-Roach ICCV‘21论文:模仿一个强化学习教练的端到端城市驾驶 文章目录 Roach输入BEV语义分割图像测量向量 Roach输出训练策略网络价值网络 具体实现由 Roach 监督的模仿学习(…...
机械臂运动学笔记(一):正向运动学
正向运动学指的是通过相邻关节间的转动和移动坐标,将末端的坐标计算出来。 反向运动学指的是已知机械臂末端的坐标,反算每个关节可能的转动和移动参数。 参考资料:4.机械臂几何法与DH表示法_哔哩哔哩_bilibili 一.任意连杆连接的变量定义&a…...
【DuodooBMS】给PDF附件加“受控”水印的完整Python实现
给PDF附件加“受控”水印的完整Python实现 功能需求 在实际工作中,许多文件需要添加水印以标识其状态,例如“受控”“机密”等。对于PDF文件,添加水印不仅可以增强文件的可识别性,还可以防止未经授权的使用。本代码的功能需求是…...
GitCode 助力 Dora SSR:开启游戏开发新征程
项目仓库(点击阅读原文链接可直达) https://gitcode.com/ippclub/Dora-SSR 跨越技术藩篱,构建游戏开发乐园 Dora SSR 是一款致力于打破游戏开发技术壁垒的开源游戏引擎。其诞生源于开发者对简化跨平台游戏开发环境搭建的强烈渴望࿰…...
Mediamtx+Python读取webrtc流
一、功能思路: 1、我采用ffmpeg -re -stream_loop -1 -i xcc.mp4 -c:v libx264 -profile:v baseline -x264opts "bframes0:repeat_headers1" -b:v 1500k -preset fast -f flv rtmp://127.0.0.1:1835/stream/111推流到mediamtx的rtmp上 2、通过mediamtx自…...
每日一题——矩阵最长递增路径
矩阵最长递增路径问题 题目描述数据范围:进阶要求:示例示例 1示例 2 题解思路算法步骤:代码实现代码解释复杂度分析总结 题目描述 给定一个 n 行 m 列的矩阵 matrix,矩阵内所有数均为非负整数。你需要在矩阵中找到一条最长路径&a…...
【CLIP系列】4:目标检测(ViLD、GLIP)
目录 1 ViLD2 GLIP2.1 前言2.2 损失计算2.3 模型框架 1 ViLD OPEN-VOCABULARY OBJECT DETECTION VIA VISION AND LANGUAGE KNOWLEDGE DISTILLATION 从标题就能看出来,作者是把CLIP模型当成一个Teacher,去蒸馏他自己的网络,从而能Zero Shot去…...
Cesium for Unity Linux版本
Cesium for Unity 直装不支持Linux 参照官方开发流程一些操作命令issues 宝藏最后运行图 参照官方开发流程 https://github.com/CesiumGS/cesium-unity/blob/main/Documentation~/developer-setup.md 系统已经安装过dotnet和cmake xuefeixuefei:~$ dotnet --version 9.0.102 …...
Spring Boot过滤器链:从入门到精通
文章目录 一、过滤器链是什么?二、为什么需要过滤器链?三、Spring Boot中的过滤器链是如何工作的?(一)过滤器的生命周期(二)过滤器链的执行流程 四、如何在Spring Boot中定义自己的过滤器&#…...
关于 IoT DC3 中驱动(Driver)的理解
在开源IoT DC3物联网系统中,驱动(Driver)扮演着至关重要的角色,它充当了软件系统与物理设备之间的桥梁。驱动的主要功能是依据特定的通信协议连接到设备,并根据设备模板中配置的位号信息进行数据采集和指令控制。不同的…...
微信小程序地图标记点,安卓手机一次性渲染不出来的问题
问题描述: 如果微信小程序端,渲染的标记物太多,安卓手机存在标记物不显示的问题,原因初步判断是地图还没有渲染完,标记物数据已经加载完了,导致没有在地图上显示。 解决办法: 使用map组件的b…...
一维差分与二维差分
差分(Difference)是一种与前缀和密切相关的技术,主要用于高效处理区间更新操作。差分数组的核心思想是通过记录相邻元素的差值来表示原数组的变化,从而将区间更新操作的时间复杂度从 O(n) 优化到 O(1)。下面详细讲解一维差分和二维…...
EasyRTC嵌入式WebRTC视频通话SDK支持Web浏览器、Linux、ARM、Android、iOS
随着互联网技术的飞速发展,实时通信(RTC)已经成为现代应用中不可或缺的一部分。无论是视频会议、在线教育、远程医疗,还是社交娱乐,实时通信技术都在其中扮演着重要角色。 然而,WebRTC技术在PC和移动端的支…...
数据库脚本MySQL8转MySQL5
由于生产服务器版本上部署的是MySQL5,而开发手里的脚本代码是MySQL8。所以只能降版本了… 升级版本与降级版本脚本转换逻辑一样 MySQL5与MySQL8版本SQL脚本区别 大多数无需调整、主要是字符集与排序规则 MySQL5与MySQL8版本SQL字符集与排序规则 主要操作&…...
【PGCCC】commit_delay 对性能的提升:PostgreSQL 基准测试
通过禁用参数可以来调整事务工作负载synchronous_commit。该措施有惊人效果。但在操作系统崩溃期间丢失已提交事务的可能性使其成为许多应用程序无法启动的因素。因此我决定写下来。 WAL 刷新是事务数据库工作负载的瓶颈 为了确保已提交的事务不会丢失,PostgreSQL…...
AI大模型随机初始化权重并打印网络结构方法(以Deepseekv3为例,单机可跑)
背景 当前大模型的权重加载和调用,主要是通过在HuggingFace官网下载并使用transformer的库来加以实现;其中大模型的权重文件较大(部分>100GB),若只是快速研究网络结构和数据流变化,则无需下载权重。本文…...
字符串解码——巧妙使用递归解题
题目描述 给定一个经过编码的字符串,返回它解码后的字符串。编码规则为 k[encoded_string],表示方括号内部的 encoded_string 重复 k 次。其中 k 是正整数,输入字符串确保符合格式要求且无额外空格。 示例: 复制 示例 1&#…...
Flask Web开发的重要概念和示例
一口气列举Flask Web应用的所有概念和示例 Flask Web 应用基本框架 路由(Routing) 模版(Template) request 对象 JSON 数据处理 redirect 示例 文件上传示例 文件下载示例 Session 示例 Cookie操作 Flask Web 应用基本框架 这是一个 最基础的 Flask Web 应用,…...
51-ArrayList
51-ArrayList Collection 类型介绍 仓颉中常用的几种基础 Collection 类型,包含 Array、ArrayList、HashSet、HashMap。 可以在不同的场景中选择适合对应业务的类型: Array:如果不需要增加和删除元素,但需要修改元素ÿ…...
Ollama+WebUI+DeepSeek部署自己的本地大模型
前言 使用AI几乎成为互联网工作者必备技能了,DeepSeek的出现把AI再次推向高潮,在本文中,我们将带领大家借助 Ollama、WebUI 和 deepseek 这三个工具,成功搭建属于自己的本地大模型环境。Ollama 作为一款轻量级的大模型运行工具&a…...
(篇六)基于PyDracula搭建一个深度学习的软件之新版本ultralytics-8.3.28调试
ultralytics-8.3.28版本debug记录 1传入文件 代码太多不粘贴在这里了,完整代码写在了篇三 def open_src_file(self):config_file config/fold.jsonconfig json.load(open(config_file, r, encodingutf-8))open_fold config[open_fold]if not os.path.exists(op…...
