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

38、【Agent】【OpenCode】本地代理分析(二)

【声明】本博客所有内容均为个人业余时间创作所述技术案例均来自公开开源项目如GithubApache基金会不涉及任何企业机密或未公开技术如有侵权请联系删除背景上篇 blog【Agent】【OpenCode】本地代理分析一开始分析本地代理的实现该本地 HTTP 代理服务器可以接收来自 OpenCode或其他兼容 OpenAI API 的客户端的请求并将请求转发给 DashScope 的 API 兼容接口其整体结构使用 Node.js 内置模块 http 创建一个本地 HTTP 服务器该服务器监听本地的2048端口所有发往http://127.0.0.1:2048的请求都会进入这个回调函数该代理只处理 OpenAI 风格的聊天请求其中条件/v1/chat/completions是 OpenCode 默认发送的 endpoint然后详细分析了 endpoint 和 OpenAI 风格的概念下面继续分析OpenCode上篇 blog 分析了 endpoint 概念并简单提了下 OpenAI 风格下面继续分析 OpenAI 风格的核心特征首先是固定的 endpoint 路径/v1/chat/completions所有的聊天请求都会发到这里其次是请求格式统一{model:qwen-plus,messages:[{role:user,content:你好}],stream:true,temperature:0.7}统一的认证方式Authorization: Bearer sk-xxxxxxxxxxxx统一的流式响应格式SSE非流式{choices:[{message:{content:你好}}]}流式每块一个 JSON{choices:[{delta:{content:你}}]}{choices:[{delta:{content:好}}]}{choices:[{delta:{content:}}]}OpenCode 只发送 OpenAI 风格的 endpoint 和格式所以本地代理这里必须监听/v1/chat/completionsOpenAI 风格 endpoint然后接收 OpenAI 格式的 JSON再转发给 DashScope 的兼容接口/compatible-mode/v1/chat/completionsOK继续分析本地代理的内容// dashscope-proxy.jsconsthttprequire(http);consthttpsrequire(https);constserverhttp.createServer((req,res){console.log( Received${req.method}${req.url});if(req.methodPOSTreq.url/v1/chat/completions){letbody;req.on(data,chunkbodychunk);req.on(end,(){// 从原始请求中获取 Authorization 头constauthHeaderreq.headers[authorization]||;constoptions{hostname:dashscope.aliyuncs.com,port:443,path:/compatible-mode/v1/chat/completions,method:POST,headers:{Authorization:authHeader,// 直接透传Content-Type:application/json,Content-Length:Buffer.byteLength(body)}};constproxyReqhttps.request(options,(proxyRes){res.writeHead(proxyRes.statusCode,proxyRes.headers);proxyRes.pipe(res);// 自动处理流式/非流式 自动 end()});proxyReq.on(error,(e){console.error(Proxy error:,e.message);res.writeHead(502);res.end(Bad Gateway);});proxyReq.write(body);proxyReq.end();});return;}res.writeHead(404);res.end(Not Found);});server.listen(2048,127.0.0.1,(){console.log(✅ DashScope proxy with full OpenCode Ollama compatibility running on http://127.0.0.1:2048);});当收到的是指定请求/v1/chat/completions时开始拼接 request bodyletbody;req.on(data,chunkbodychunk);req.on(end,(){...});这里的 HTTP request body 可能是分块chunked传输的通过监听data事件把所有数据块拼成完整的字符串 body然后当end事件触发时说明整个 request body 已经接收完毕可以开始处理注意此时的 body 仍是个 JSON 字符串而不是 JS 对象除非像之前 blog 【Agent】【OpenCode】本地代理JavaScript 脚本 介绍的要用JSON.parse解析并修改 request body 的内容此时的 body 内容可能是这样的{model:qwen-plus,messages:[{role:user,content:你好}]}这里涉及比较多的点下面详细分析下首先是分块传输的概念分块传输Chunked Transfer Encoding是 HTTP/1.1 中一种动态传输数据的方式适合服务器在发送响应或客户端发送请求时还不知道整个内容的场景在分块传输中数据被分成多个块chunks进行发送每个块前面标明该数据块的大小最后一个大小为 0 的块表示结束举个原始 HTTP 响应片断的例子HTTP/1.1 200 OK Transfer-Encoding: chunked 5\r\n ← 第一块长度是 5 字节 Hello\r\n ← 实际数据 Hello 6\r\n ← 第二块长度是 6 字节 World\r\n ← 实际数据 World 0\r\n ← 长度为 0表示结束 \r\n最终数据流拼接起来就是Hello World另外注意Transfer-Encoding: chunked出现时不会同时有Content-Length字段在这段代码中letbody;req.on(data,chunkbodychunk);req.on(end,(){// 完整 body 内容});Node.js 底层已经自动解码了分块传输所以这里收到的每个 chunk 都是原始数据的一部分Buffer 或 string不需要手动解析十六进制长度所以无论是客户端是用Content-Length一次性发完数据还是用 chunked 分多次发送本地代理都能正确拼出完整 bodyOK下面再介绍下分块传输的适用场景场景说明流式响应如大模型聊天streamtrue一边生成 token一边发送动态生成内容服务器实时读取日志执行命令并输出上传大文件客户端可能分块上传虽然较少见但 HTTP 允许代理转发接收 OpenCode 请求时可能会收到 chunked body比如上面第一个流式响应所以本地代理这里监听data和end是处理 HTTP 请求的标准做法能兼容所有传输方式OK本篇先到这里如有疑问欢迎评论区留言讨论祝各位功力大涨技术更上一层楼更多内容见下篇 blog

相关文章:

38、【Agent】【OpenCode】本地代理分析(二)

【声明】本博客所有内容均为个人业余时间创作,所述技术案例均来自公开开源项目(如Github,Apache基金会),不涉及任何企业机密或未公开技术,如有侵权请联系删除 背景 上篇 blog 【Agent】【OpenCode】本地代…...

37、【Agent】【OpenCode】本地代理分析(一)

【声明】本博客所有内容均为个人业余时间创作,所述技术案例均来自公开开源项目(如Github,Apache基金会),不涉及任何企业机密或未公开技术,如有侵权请联系删除 背景 上篇 blog 【Agent】【OpenCode】本地代…...

零成本构建开源串流服务器:跨设备体验全攻略

零成本构建开源串流服务器:跨设备体验全攻略 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine 在多设备互联的时代,如何打破硬件限制,让高性能游戏…...

Markor:Android平台终极文本编辑器完全指南

Markor:Android平台终极文本编辑器完全指南 【免费下载链接】markor Text editor - Notes & ToDo (for Android) - Markdown, todo.txt, plaintext, math, .. 项目地址: https://gitcode.com/gh_mirrors/ma/markor 寻找一款真正轻量级却又功能全面的Andr…...

5分钟掌握B站视频下载的终极解决方案

5分钟掌握B站视频下载的终极解决方案 【免费下载链接】BiliDownloader BiliDownloader是一款界面精简,操作简单且高速下载的b站下载器 项目地址: https://gitcode.com/gh_mirrors/bi/BiliDownloader 还在为无法保存喜欢的B站视频而烦恼吗?BiliDow…...

YimMenu:GTA V安全防护与体验增强解决方案

YimMenu:GTA V安全防护与体验增强解决方案 【免费下载链接】YimMenu YimMenu, a GTA V menu protecting against a wide ranges of the public crashes and improving the overall experience. 项目地址: https://gitcode.com/GitHub_Trending/yi/YimMenu Yi…...

DownKyi:3个真实案例揭示如何高效解决B站视频下载难题

DownKyi:3个真实案例揭示如何高效解决B站视频下载难题 【免费下载链接】downkyi 哔哩下载姬downkyi,哔哩哔哩网站视频下载工具,支持批量下载,支持8K、HDR、杜比视界,提供工具箱(音视频提取、去水印等&#…...

数字游民装备:OpenClaw+Qwen3-32B的轻量化旅行方案

数字游民装备:OpenClawQwen3-32B的轻量化旅行方案 1. 为什么数字游民需要本地AI助手 去年在巴厘岛旅居时,我深刻体会到数字游民的工作痛点:不稳定的网络、时区差异导致的协作延迟、以及移动办公场景下的效率损耗。当你在咖啡馆处理文件时&a…...

智能家居集成新方案:Home Assistant与小米设备的跨平台控制实现

智能家居集成新方案:Home Assistant与小米设备的跨平台控制实现 【免费下载链接】ha_xiaomi_home Xiaomi Home Integration for Home Assistant 项目地址: https://gitcode.com/GitHub_Trending/ha/ha_xiaomi_home 【突破生态限制】智能家居跨平台集成方案 …...

OFA视觉蕴含模型快速入门:Web界面操作,轻松实现图文验证

OFA视觉蕴含模型快速入门:Web界面操作,轻松实现图文验证 1. 认识OFA视觉蕴含模型 1.1 什么是视觉蕴含? 想象一下这样的场景:你看到一张照片,里面有两只猫在玩耍。如果有人问"照片里有动物吗?"…...

StructBERT-Large镜像部署教程:GPU加速推理环境搭建指南

StructBERT-Large镜像部署教程:GPU加速推理环境搭建指南 1. 环境准备与快速部署 在开始部署StructBERT-Large镜像之前,我们需要确保基础环境配置正确。这个步骤将帮助你快速搭建起可运行的GPU加速推理环境。 1.1 硬件与系统要求 为了获得最佳性能&am…...

实测梦幻动漫魔法工坊:用LoRA调整画风,轻松打造不同风格的动漫作品

实测梦幻动漫魔法工坊:用LoRA调整画风,轻松打造不同风格的动漫作品 1. 工具概览 梦幻动漫魔法工坊是一款基于Diffusion模型和LoRA微调技术的动漫图像生成工具。它最大的特点是通过简单的界面操作,就能生成各种风格的二次元图像,…...

企业级应用权限架构设计与实践指南

企业级应用权限架构设计与实践指南 【免费下载链接】react Reactwebpackreduxant designaxiosless全家桶后台管理框架 项目地址: https://gitcode.com/gh_mirrors/reac/react 一、概念解析:权限管理的核心要素 🔍 权限管理是企业级应用的安全基…...

python 文件管理库 Path 解析(详细基础)

1 Path库能做什么: Path库是python常见的文件操作库(以对象形式操作文件路径),可以进行以下操作: 文件路径的拼接(example: test / Your_path / files ) 文件地址的提取(提取名称、…...

解放你的文件夹:智能文件整理Agent,让杂乱文件一键归位

核心功能:不止是“按类型分类”市面上很多文件整理工具只能简单按后缀名归类,但实际使用中我们的需求远不止于此——比如按项目维度、按时间前缀、按业务场景整理,甚至要区分大文件/近期文件避免误操作。这款工具的核心亮点在于:1…...

FontForge完整指南:免费开源字体设计工具的终极解决方案

FontForge完整指南:免费开源字体设计工具的终极解决方案 【免费下载链接】fontforge Free (libre) font editor for Windows, Mac OS X and GNULinux 项目地址: https://gitcode.com/gh_mirrors/fo/fontforge 寻找一款功能全面且完全免费的字体设计工具&…...

ai辅助开发新体验:在快马平台生成复杂算法代码,赋能idea社区版项目

今天想和大家分享一个特别实用的开发体验:如何用AI辅助快速生成复杂算法代码,再无缝导入IDEA社区版进行调试优化。整个过程就像有个编程助手在身边,效率提升非常明显。 需求背景 最近在做一个需要动态计算数学表达式的项目,要求…...

抖音无水印批量下载工具:高效内容采集解决方案

抖音无水印批量下载工具:高效内容采集解决方案 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback support. 抖音…...

别再东拼西凑了!保姆级教程:用Anaconda在Windows上搞定PaddleOCR CPU版(附shapely安装避坑指南)

从零到一:Windows下Anaconda环境配置PaddleOCR全攻略 在文字识别技术领域,PaddleOCR以其出色的性能和易用性赢得了众多开发者的青睐。但对于初学者而言,从环境配置到成功运行往往充满挑战——版本冲突、依赖缺失、环境变量配置等问题层出不穷…...

效率倍增:用快马生成openclaw一键式部署与配置工具

效率倍增:用快马生成openclaw一键式部署与配置工具 最近在团队协作时遇到了一个头疼的问题:每次新成员加入或者更换开发机,都需要手动部署openclaw环境。这个过程中不仅需要重复下载、解压、配置,还经常因为网络代理、权限等问题…...

5分钟终极指南:如何让加密音乐文件重获自由

5分钟终极指南:如何让加密音乐文件重获自由 【免费下载链接】unlock-music 在浏览器中解锁加密的音乐文件。原仓库: 1. https://github.com/unlock-music/unlock-music ;2. https://git.unlock-music.dev/um/web 项目地址: https://gitcode…...

从 ReAct 到 Workflow:基于云端 API 构建事件驱动的智能体

1. 什么是WorkFlow 之前咱们的用法是一种QueryEngine的用法,就是将大模型当成一个查询的工具在使用,而workflow是LlmaIndex的新一代编排引擎。 1.1 核心逻辑 LlamaIndex的workflow,本质上是一个事件驱动(Event-driven&#xff…...

5分钟掌握gInk:Windows上最简单高效的免费屏幕标注工具完整指南

5分钟掌握gInk:Windows上最简单高效的免费屏幕标注工具完整指南 【免费下载链接】gInk An easy to use on-screen annotation software inspired by Epic Pen. 项目地址: https://gitcode.com/gh_mirrors/gi/gInk 你是否曾在演示时想要快速圈出重点数据&…...

OpenClaw与Python:构建高效自动化脚本,赋能复杂工作场景落地

OpenClaw与Python:构建高效自动化脚本,赋能复杂工作场景落地摘要在数字化转型浪潮席卷全球的今天,自动化技术已成为提升企业运营效率、降低人力成本、应对复杂业务挑战的关键利器。其中,机器人流程自动化(RPA&#xff…...

费城“敬畏部”:AI 与艺术融合的新奇沉浸式体验

【导语:费城全新沉浸式艺术体验项目“敬畏部”,由多位艺术家打造,融合了 AI 技术。它以独特的方式让游客与艺术互动,探讨了个人数据存储等主题,为 AI 在艺术领域的应用提供了新视角。】“敬畏部”:费城的新…...

【5大突破】WarcraftHelper:让经典RTS重获新生的跨系统优化方案

【5大突破】WarcraftHelper:让经典RTS重获新生的跨系统优化方案 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper WarcraftHelper作为开源解…...

(转发需官方授权)生活中遇到的知识:(转发需官方授权)有些饭店办公的人多所以有个办公地的营业执照也会有一个饭店的营业执照这种情况起码这个主打饭店运营的办公地的公司有起码有两个子饭店其中一个是主饭店。

(转发需官方授权)生活中遇到的知识:(转发需官方授权)有些饭店办公的人多所以有个办公地的营业执照也会有一个饭店的营业执照这种情况起码这个主打饭店运营的办公地的公司有起码有两个子饭店其中一个是主饭店。...

互联网时代出现过的电脑病毒之“小球病毒”也叫“乒乓病毒”的电脑和安卓手机上出现过的病毒“乒乓病毒”简介

(转发需官方授权) 互联网时代出现过的电脑病毒之“小球病毒”也叫“乒乓病毒”的电脑和安卓手机上出现过的病毒“乒乓病毒”简介 1989年4月,西南铝厂一台正在工作的计算机屏幕上突然跳出一个小方块。 ​​​1989年4月,西南铝厂一…...

BiliTools:2026年最强大的免费哔哩哔哩资源管理工具终极指南

BiliTools:2026年最强大的免费哔哩哔哩资源管理工具终极指南 【免费下载链接】BiliTools A cross-platform bilibili toolbox. 跨平台哔哩哔哩工具箱,支持下载视频、番剧等等各类资源 项目地址: https://gitcode.com/GitHub_Trending/bilit/BiliTools …...

(支援发出,转发需官方授权)某个名师大家可能还是一个女的自称“廉者不受嗟来之食”对自己对自己的学生和想要招(找)的学生都一样。

(支援发出,转发需官方授权)某个名师大家可能还是一个女的自称“廉者不受嗟来之食”对自己对自己的学生和想要招(找)的学生都一样。...