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

.NET 9实战|最新C# AI Agent开发,Semantic Kernel+OpenClaw双剑合璧

文章目录别再用Python写Agent了C#也能整先搞明白Semantic Kernel和OpenClaw到底是个啥环境准备.NET 9装起来5分钟搞定第一招Semantic Kernel基础先把AI大脑接进来第二招接入OpenClaw让AI真正能动手实战双剑合璧打造一个自动研究员踩坑实录这些坑我替你踩过了1. 异步地狱要当心2. OpenClaw的Docker网络问题3. Token消耗像个黑洞4. JSON序列化的大小写进阶玩法让Agent更聪明结语C#的AI时代真的来了目前国内还是很缺AI人才的希望更多人能真正加入到AI行业共同促进行业进步增强我国的AI竞争力。想要系统学习AI知识的朋友可以看看我精心打磨的教程 http://blog.csdn.net/jiangjunshow教程通俗易懂高中生都能看懂还有各种段子风趣幽默从深度学习基础原理到各领域实战应用都有讲解我22年的AI积累全在里面了。注意教程仅限真正想入门AI的朋友否则看看零散的博文就够了。别再用Python写Agent了C#也能整说实话最近AI Agent火得有点离谱。打开GitHubTrending满屏的Python项目搞得咱们.NET开发者心里直痒痒但又有点慌——难道C#真就只能在旁边看热闹答案是扯淡.NET 9正式发布之后配合微软的Semantic Kernel和最近爆火的OpenClaw框架咱们用C#写AI Agent不仅行而且行得很爽。今天这篇文章我就手把手教你如何把这两把瑞士军刀和万能机械手组合起来打造一个能自己上网查资料、写代码、甚至操作浏览器的真·AI Agent。不搞那些虚的直接上代码看完你就能跑起来。先搞明白Semantic Kernel和OpenClaw到底是个啥很多兄弟一上来就被这两个名词整懵了。别急我用大白话给你翻译翻译。Semantic Kernel简称SK你可以理解成AI界的乐高积木。它是微软官方出的SDK专门用来给大模型GPT-4、Claude、Qwen都行编排技能。你想让AI干啥查天气写邮件操作数据库在SK里这些都叫Plugin插件。SK负责把这些插件串起来让AI自己决定先干啥后干啥就像给AI配了个聪明的大脑。OpenClaw呢这玩意儿最近火得一塌糊涂简单来说它是Agent界的万能机械手。OpenClaw基于Claude的Computer Use能力开源实现能让AI真正操控你的电脑——打开浏览器、点击按钮、下载文件、运行终端命令。以前AI只能嘴上说说有了OpenClaw它真能动手动脚。为啥要双剑合璧因为SK管想OpenClaw管做。SK负责编排逻辑OpenClaw负责落地执行。这俩一组合你的C#程序就能从一个简单的聊天机器人进化成能独立干活的数字实习生。环境准备.NET 9装起来5分钟搞定工欲善其事先利其器。咱们先把开发环境整利索。首先确保你装了**.NET 9 SDK**2024年11月发布的LTS版本稳得很。命令行跑一下dotnet--version显示9.0.xxx就对了。然后新建个项目咱们搞个控制台应用就行dotnet new console-nCSharpAgentDemocdCSharpAgentDemo接下来装NuGet包。Semantic Kernel现在最新稳定版是1.6直接拉满dotnetaddpackage Microsoft.SemanticKernel--version1.6.0 dotnetaddpackage Microsoft.SemanticKernel.Plugins.Web--version1.6.0还需要一个HTTP客户端来调用OpenClaw因为OpenClaw通常以Docker服务或本地API形式部署dotnetaddpackage System.Net.Http.Json--version9.0.0搞定现在打开Program.cs咱们开始写真家伙。第一招Semantic Kernel基础先把AI大脑接进来SK的核心概念就三个Kernel内核、Plugin插件、Function函数。别被名词吓到说白了就是你教AI几项技能然后让它自己用。先整个简单的让AI能说话还能查个天气模拟的usingMicrosoft.SemanticKernel;usingMicrosoft.SemanticKernel.ChatCompletion;// 配置你的API Key这里以OpenAI为例Claude的API也类似varbuilderKernel.CreateBuilder();builder.AddOpenAIChatCompletion(modelId:gpt-4,apiKey:your-api-key-here);varkernelbuilder.Build();// 定义一个简单的插件假装查天气publicclassWeatherPlugin{[KernelFunction,Description(获取指定城市的天气)]publicstringGetWeather([Description(城市名)]stringcity){// 实际项目中这里应该调真实API咱们先模拟return${city}今天晴25度适合写代码;}}// 把插件注册给Kernelkernel.Plugins.AddFromTypeWeatherPlugin();// 试试效果varchatkernel.GetRequiredServiceIChatCompletionService();varhistorynewChatHistory();history.AddUserMessage(北京今天天气怎么样);varresultawaitchat.GetChatMessageContentAsync(history,kernel);Console.WriteLine(result);// AI会调用插件并告诉你天气看到没这就是SK的精髓。你把工具Plugin准备好AI会根据用户的话自己判断该用哪个工具。这不是简单的if-else而是大模型在理解语义后做出的决策。第二招接入OpenClaw让AI真正能动手好了现在AI有脑子了但还缺双手。OpenClaw就是来干这个脏活累活的。通常OpenClaw会跑在Docker里暴露一个HTTP API默认可能是http://localhost:8080。咱们需要在SK里创建一个Plugin专门用来调用OpenClaw的服务。usingSystem.Net.Http.Json;usingSystem.Text.Json;usingMicrosoft.SemanticKernel;publicclassOpenClawPlugin{privatereadonlyHttpClient_httpClient;publicOpenClawPlugin(){_httpClientnewHttpClient{BaseAddressnewUri(http://localhost:8080)};}[KernelFunction,Description(让AI操作浏览器执行任务比如搜索资料、下载文件)]publicasyncTaskstringExecuteTask([Description(要执行的具体任务描述越详细越好)]stringtask){try{// 调用OpenClaw的API创建任务varresponseawait_httpClient.PostAsJsonAsync(/api/tasks,new{instructiontask,timeout300// 5分钟超时});response.EnsureSuccessStatusCode();varresultawaitresponse.Content.ReadFromJsonAsyncOpenClawResult();return$任务执行完成{result?.Output??无输出};}catch(Exceptionex){return$执行失败{ex.Message};}}privateclassOpenClawResult{publicstringOutput{get;set;}publicstringStatus{get;set;}}}这段代码干啥的其实就是给SK包了一层壳让SK能通过调用OpenClawPlugin.ExecuteTask来使唤OpenClaw。比如AI想帮我查一下.NET 9的新特性并保存到文件它就会调用这个函数把任务发给OpenClawOpenClaw真的打开Chrome上微软官网把内容扒下来存好。实战双剑合璧打造一个自动研究员现在咱们把两者合起来搞个有点用的东西自动研究员。你告诉它一个主题它自己去网上查资料然后整理成Markdown文档。usingMicrosoft.SemanticKernel;usingMicrosoft.SemanticKernel.ChatCompletion;usingMicrosoft.SemanticKernel.Connectors.OpenAI;// 初始化Kernel这次加上两个插件varbuilderKernel.CreateBuilder();builder.AddOpenAIChatCompletion(gpt-4,your-key);builder.Plugins.AddFromTypeWeatherPlugin();// 之前定义的天气插件可有可无builder.Plugins.AddFromTypeOpenClawPlugin();// 咱们的OpenClaw神器varkernelbuilder.Build();// 设置执行策略允许自动调用插件varexecutionSettingsnewOpenAIPromptExecutionSettings{ToolCallBehaviorToolCallBehavior.AutoInvokeKernelFunctions};varchatServicekernel.GetRequiredServiceIChatCompletionService();varchatHistorynewChatHistory();Console.WriteLine( C# AI Agent 启动 );Console.WriteLine(请输入研究主题比如.NET 9新特性);vartopicConsole.ReadLine();chatHistory.AddSystemMessage( 你是一个专业的技术研究员。你的任务是1.使用OpenClaw工具搜索相关资料2.整理成结构化的技术报告3.保存到本地文件 注意如果搜索失败请告诉用户具体原因。);chatHistory.AddUserMessage($请帮我研究一下{topic}并写一份简短的技术总结保存到桌面);// 开始执行AI会自动决策调用哪些工具varresponseawaitchatService.GetChatMessageContentAsync(chatHistory,executionSettings,kernel);Console.WriteLine(\n Agent执行结果 );Console.WriteLine(response.Content);// 如果AI调用了OpenClaw它真的会在后台开浏览器去查资料// 然后把结果写回对话最后生成总结看到这段代码的威力没你啥都没硬编码就给了AI一个目标和一套工具它自己就能规划“哦用户要查.NET 9我需要调用OpenClaw去搜微软文档然后整理成Markdown”。这就是真正的Agent行为不是简单的问答机器人。踩坑实录这些坑我替你踩过了说实话第一次把这俩框架捏一块儿的时候我也被坑得不要不要的。给你列几个常见的省得你半夜 Debugging1. 异步地狱要当心SK和OpenClaw全是异步操作async/await用得不对直接死锁。.NET 9虽然优化了性能但异步逻辑还是得老老实实写。记住别在异步方法里混用.Result不然分分钟教做人。2. OpenClaw的Docker网络问题如果你把OpenClaw跑在Docker里localhost可能访问不到。得把容器网络模式设为hostLinux或者映射端口时仔细配置。我当初就是没注意这个AI一直报连接失败查了半天才发现是Docker网络隔离的问题。3. Token消耗像个黑洞让AI自动决策意味着可能会多次调用大模型。SK默认的AutoInvoke模式虽然爽但一不小心就烧掉几百Tokens。建议加个预算控制或者在System Prompt里限制思考步骤“最多思考3步别瞎折腾”。4. JSON序列化的大小写OpenClaw的API可能用camelCaseC#默认PascalCase.PostAsJsonAsync有时候对不齐。建议显式设置JsonSerializerOptionsvaroptionsnewJsonSerializerOptions{PropertyNamingPolicyJsonNamingPolicy.CamelCase};进阶玩法让Agent更聪明基础跑通之后你可以整点花的记忆功能用SK的Memory或者接个向量数据库比如Qdrant、Milvus让Agent记得你上周让它查过啥避免重复劳动。多Agent协作建好几个Kernel实例一个专门搜索一个专门写代码一个专门测试然后用SK的Agent功能1.5版本支持让它们协作像个小团队一样干活。本地化部署不想用OpenAI API把模型换成Ollama本地跑的Llama 3.2或者Qwen 2.5配合OpenClaw的本地版本整套东西完全离线运行数据隐私稳得一批。结语C#的AI时代真的来了写到这儿说实话我有点感慨。以前总觉得搞AI是Python的天下C#只能做做后台。但.NET 9的性能提升特别是GC和AOT编译优化加上Semantic Kernel这种第一方SDK的成熟咱们C#开发者现在完全有能力在AI Agent这个赛道分一杯羹。OpenClaw这类工具的出现更是打破了AI只能聊天的局限。当SK的编排能力遇上OpenClaw的执行能力C#不仅能写AI应用还能写真正能改变物理世界或者说数字世界的智能体。别再观望了把代码clone下来跑一跑。说不定下一个爆款AI工具就是你用.NET 9写的。目前国内还是很缺AI人才的希望更多人能真正加入到AI行业共同促进行业进步增强我国的AI竞争力。想要系统学习AI知识的朋友可以看看我精心打磨的教程 http://blog.csdn.net/jiangjunshow教程通俗易懂高中生都能看懂还有各种段子风趣幽默从深度学习基础原理到各领域实战应用都有讲解我22年的AI积累全在里面了。注意教程仅限真正想入门AI的朋友否则看看零散的博文就够了。

相关文章:

.NET 9实战|最新C# AI Agent开发,Semantic Kernel+OpenClaw双剑合璧

文章目录别再用Python写Agent了,C#也能整!先搞明白:Semantic Kernel和OpenClaw到底是个啥?环境准备:.NET 9装起来,5分钟搞定第一招:Semantic Kernel基础,先把AI大脑接进来第二招&…...

MYSQL【表操作】

【MySQL 笔记】表操作(DDL - Data Definition Language)详解 MySQL 中对表的操作主要属于 DDL(数据定义语言),包括创建表、修改表、删除表、重命名表、复制表、查看表结构等。 下面按常用程度和重要性排序&#xff0…...

58万票!星特杯投票进入冲刺阶段

自“星特杯”评选活动启动以来,行业内外参与积极,投票热度持续攀升。来自行业上下游企业、工程师以及专业读者的积极参与,使得本届评选热度不断攀升。截至目前,活动总投票数已突破58万票,评选影响力正在持续扩大。 从当…...

【2026年-11期】Where lies the future of humanity in the age of AI?

当 AI 成为 “能力基础设施”,人类的未来在哪里?一、稀缺与丰饶:人与 AI 的本质分野人类的能力天生带着稀缺性烙印:我们的时间是线性的,一天只有 24 小时;注意力是有限的,一次只能专注几件事&am…...

java基于springboot微信小程序的大学生心理音乐治疗的设计与实现

目录系统架构设计数据库设计微信小程序开发后端接口开发音乐推荐算法测试与部署迭代优化项目技术支持可定制开发之功能创新亮点源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作系统架构设计 采用SpringBoot作为后端框架,微信小程…...

SkyReels-Text:Fine-grained Font-Controllable Text Editing for Poster Design

1.introduction专业工作流中一个关键要求是能够快速修改文本内容,同时保持原始的视觉和谐,排版身份和美学意图,这不仅要求精准的字符展示,还需要对字体家族和风格细微差别的精细控制,尤其是在处理像手写文本这样复杂的…...

个性化定制+移动应用,ERP系统新玩法的魅力你知道吗?

ERP系统新玩法,全方位优化企业运营流程在当今竞争激烈的商业环境中,企业要想脱颖而出,高效的运营流程至关重要。ERP系统作为企业管理的核心工具,正迎来新的玩法,为企业带来全方位的优化。一、传统ERP系统的局限性传统的…...

算法的试金石:模型训练、评估与调优的艺术

前言: 在上一篇博客中,我们化身“数据炼金术师”,将杂乱无章的原始数据清洗、编码、缩放,打磨成了晶莹剔透的“特征宝石”。现在,这些宝石已经整齐地摆放在实验台上,等待着被赋予生命。 本篇是“机器学习实…...

3月18日GitHub热门项目推荐|我不得不把OpenClaw排除一下

1. N8n - 可视化工作流自动化平台📈 星标增长:快速增长的工作流自动化工具🔧 关键技术:TypeScript、Node.js、400集成📅 最新更新:2026年03月🔗 项目链接:https://github.com/n8n-io…...

纯内网聊天工具分享

工具设计与实现纯内网聊天工具的设计基于局域网通信协议,无需连接互联网即可实现设备间的消息传递。采用轻量级架构,确保在资源有限的设备上也能流畅运行。核心功能包括消息发送、接收、用户列表管理以及简单的文件传输。开发过程中利用AI辅助生成部分代…...

康复训练 7

TCP四次挥手的过程?每一步的状态变化?假如客户端要断开连接,在第一次挥手,客户端确认没东西发送后,发送fin报文给服务端,自己状态从established变为fin wait 1,服务端收到fin后从established变为…...

面对大厂抄袭的指控,OpenClaw是否有足够的知识产权法律武器来保护自己?还是只能依靠舆论?

开源协议的选择,尤其是像MIT这样宽松的许可,一直是技术社区里一个既实用又微妙的话题。当讨论到像OpenClaw这样的项目时,问题往往不只是法律条文上的“能不能”,而是更深一层的“该不该”,以及随之而来的社区反应。 从…...

计算机毕业设计springboot基于web的精品课程网站 SpringBoot框架驱动的在线教育优质课程资源平台设计与实现 基于Java Web的数字化精品课程学习与交流系统开发

计算机毕业设计springboot基于web的精品课程网站(配套有源码 程序 mysql数据库 论文) 本套源码可以在文本联xi,先看具体系统功能演示视频领取,可分享源码参考。 随着互联网技术的迅猛发展和全球教育数字化转型的加速推进,传统教育…...

C# 中 ?、??、??=、?: 、?. 、?[] 各种问号的用法和说明

在 C# 中,问号(?)远不止是一个简单的标点符号。随着语言版本的迭代更新,C# 围绕问号(?)发展出了一套强大而优雅的空值处理和条件表达机制。熟练掌握这些操作运算符不仅能大幅提升代码的简洁性和可读性&am…...

AI智能分析系统在民宿的应用解决方案

目录 引言 一、方案背景与客户需求 方案背景 客户需求 二、AI智能分析系统方案说明 系统架构 前端设备 AI Box边缘计算设备 算法部署与应用 三、实施效果与优势 实施效果 方案优势 四、结论与展望 引言 随着旅游业的蓬勃发展以及智能化生活需求的增长,智慧民宿…...

php方案 PHP实现负载均衡客户端

<?php// 轮询&#xff1a;挨个来class RoundRobin {private int $i 0;public function __construct(private array $servers) {}public function pick(): string { return $this->servers[$this->i % count($this->servers)]; }}// 加权轮询&#xff1a;权重高的…...

MCP项目笔记三(server)

MCP Server服务端设计&#xff1a;请求分发、回调注册、通知发送与 transport 连接 Server 实现了一个典型 MCP 服务端骨架的核心结构。它并不直接承载具体业务&#xff0c;而是提供了一组通用能力&#xff0c;包括&#xff1a; 请求接收与 JSON 解析方法分发回调覆盖异步通知发…...

uni.requestMerchantTransfer-安卓APP中商家转账用户确认模式下,拉起页面请求用户确认收款

刚使用这个插件的时候很迷茫&#xff0c;不知道从何下手&#xff0c;问社区和专门的插件交流群几乎石层大海&#xff0c;索性在自己两天的摸索中终于成功了&#xff0c;下面是我成功的经验进行分享&#xff1b;目前只使用了安卓版 ①下载插件&#xff1a; ②下载后&#xff0c…...

智慧大屏+数字人:企业数据交互的下一个十年

【导语】 还在用鼠标点点点查数据&#xff1f;现在&#xff0c;说一句"展示本月销售数据"&#xff0c;数字人就能秒级调取并语音播报。这不是科幻&#xff0c;而是正在落地的智慧大屏新形态。一、什么是"智慧大屏数字人"&#xff1f;简单说&#xff0c;就是…...

运维那些事儿(9):运维知识库,串联全流程的运维效率神器

前八期我们从IT资产管理、监控工具、U 位管理到自动化方案&#xff0c;搭建起了完整的精细化运维体系。但后台不少小伙伴反馈&#xff1a;“故障排查时翻记录半天找不到方案”“新人上手慢&#xff0c;老员工经验没法复用”“流程太多记混操作步骤”—— 这些痛点的核心&#x…...

铺布机在服装厂不同裁剪方式中的配套应用与工艺衔接

服装厂的裁剪方式多种多样&#xff0c;从传统的手工电剪到现代化的自动裁剪机&#xff0c;每种裁剪方式对铺布工序的要求各不相同。铺布机与裁剪方式的配套衔接&#xff0c;直接影响裁剪单元的整体效率和裁片质量。本文从裁剪方式角度&#xff0c;探讨铺布机在不同裁剪场景中的…...

直接上结论:全领域适配!最强AI论文工具 —— 千笔·专业论文写作工具

你是否曾在论文写作中感到力不从心&#xff1f;选题无头绪、文献难查找、框架混乱、查重率高、格式反复出错……这些困扰让无数学生在学术路上步履维艰。而如今&#xff0c;一款真正能解决这些问题的AI论文工具——千笔AI&#xff0c;正悄然改变着学术写作的方式。它不仅具备全…...

IOP-JPCS出版|EI会议2026年计算力学与智能系统国际学术会议(CMSS 2026)

高录用 | EI稳定检索 | 福耀科技大学主办 组团投稿越多&#xff0c;优惠则越多&#xff08;2篇即可成团&#xff0c;联系会务组&#xff09; 早投稿早审核早录用&#xff01;*会务组张老师微信/电话&#xff1a;14748150307 • 福耀科技大学 福耀科技大学坚持社会主义办学方向…...

不必远行,武汉家门口的徒步路线,美到不想停

武汉的山水格局&#xff0c;为城市徒步提供了丰富的舞台。无论是中心城区的湖光山色&#xff0c;还是郊野的苍翠古寨&#xff0c;多条徒步路线各具风貌&#xff0c;吸引着市民用脚步丈量身边的风景。其中&#xff0c;东湖磨山景区以其独特的立体景观&#xff0c;成为一条融合了…...

【无标题】嵌入式控制器原理及应用——STM32微控制器开发工具

摘要本文围绕《嵌入式控制器原理及应用》教材第三章核心内容&#xff0c;聚焦STM32微控制器开发工具体系&#xff0c;从开发环境搭建、编译调试工具、硬件调试辅助工具三个维度展开详解&#xff0c;结合实操案例梳理工具选型逻辑与使用技巧&#xff0c;旨在帮助读者快速构建STM…...

云原生安全实战:如何在 K8s 集群中为 Ingress 开启 HTTPS 绿锁?

&#x1f512; 云原生安全实战&#xff1a;如何在 K8s 集群中为 Ingress 开启 HTTPS 绿锁&#xff1f; 在生产环境&#xff08;Prod&#xff09;的架构设计中&#xff0c;安全永远是“第一优先级”。对于涉及敏感数据的微服务平台&#xff0c;全站 HTTPS 加密是不可逾越的合规底…...

机票改签怎么收费?写给第一次坐飞机的你,改签操作与费用全攻略

作品声明&#xff1a;个人观点、仅供参考。对于没怎么坐过飞机的人来说&#xff0c;订完机票后最担心的不是航班延误&#xff0c;而是“万一那天有事去不了怎么办”。机票改签怎么收费&#xff1f;这个问题的答案往往藏在密密麻麻的订票条款里&#xff0c;看得人一头雾水。今天…...

vTaskDelay 与 vTaskDelayUntil 对比

vTaskDelay&#xff1a;相对延时&#xff0c;从调用时开始延时&#xff0c;周期不精准&#xff08;受任务执行时间影响&#xff09;vTaskDelayUntil&#xff1a;绝对延时&#xff0c;让任务固定周期精准运行&#xff0c;不受任务执行时间影响一、底层核心原理1. vTaskDelay( xT…...

16位元灰阶X光片增强的实践

采用多步骤产生较好的增强效果&#xff0c;如多尺度细节增强、gamma调整、增强锐度等等算法最终达到这样的效果&#xff0c;欢迎对这样技术感兴趣的人士交流讨论。联系邮箱&#xff1a;yinchine2019gmail.com...

AI建站工具零基础极速上手教程:10分钟从注册到发布

AI建站工具零基础极速上手教程&#xff1a;10分钟从注册到发布 “听说AI能建站&#xff0c;但我连域名是什么都搞不清楚&#xff0c;真的能自己搞定吗&#xff1f;” 这是很多小白的真实心声。面对“做网站”这件事&#xff0c;最大的障碍往往不是工具本身&#xff0c;而是那种…...