Semantic Kernel/C#:接入智谱AI的两种方式

Semantie Kernel中对话请求默认是发送到OpenAI去的:

其他与OpenAI对话请求接口兼任的模型平台,一般只需要修改host即可,如下所示:

csharp 复制代码
 default:
     uriBuilder = new UriBuilder(request.RequestUri)
     {
         // 这里是你要修改的 URL
         Scheme = "https",
         Host = host,
         Path = "v1/chat/completions",
     };
     request.RequestUri = uriBuilder.Uri;
     break;

但是智谱AI的对话接口地址如下:

在python中这样就可以用,但SemanticKernel中好像还没有base_url的设置。

有两种方式可以实现。

一种是想和之前其他模型用相同的方式,把智普平台作为一种特殊的方式处理。

在appsettings.json中添加一个Platform字段,请求接口完全兼容OpenAI的可以不写:

创建Kernel是这样的:

csharp 复制代码
 var builder = Kernel.CreateBuilder()
 .AddOpenAIChatCompletion(
    modelId: OpenAIOption.ChatModel,
    apiKey: OpenAIOption.Key,
    httpClient: new HttpClient(handler));
_kernel = builder.Build();

然后在OpenAIHttpClientHandler为智谱平台做一下不同的处理:

csharp 复制代码
public class OpenAIHttpClientHandler : HttpClientHandler
{
    protected override async Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
    {
        UriBuilder uriBuilder;
        string url = OpenAIOption.Endpoint;
        string platform = OpenAIOption.Platform;
        Uri uri = new Uri(url);
        string host = uri.Host;
        switch (request.RequestUri?.LocalPath)
        {
            case "/v1/chat/completions":
                switch(platform)
                {
                    case "ZhiPu":
                        uriBuilder = new UriBuilder(request.RequestUri)
                        {
                            // 这里是你要修改的 URL
                            Scheme = "https",
                            Host = host,
                            Path = "api/paas/v4/chat/completions",
                        };
                        request.RequestUri = uriBuilder.Uri;
                        break;
                    default:
                        uriBuilder = new UriBuilder(request.RequestUri)
                        {
                            // 这里是你要修改的 URL
                            Scheme = "https",
                            Host = host,
                            Path = "v1/chat/completions",
                        };
                        request.RequestUri = uriBuilder.Uri;
                        break;
                }
                break;
        }
    
        HttpResponseMessage response = await base.SendAsync(request, cancellationToken);
      
        return response;
    }
}

尝试是否成功:

另一种方式更加简单,只需要在appsettings.json中这样写:

使用这种方式创建Kernel即可:

尝试是否成功:

在AvaloniaChat中为了和其他平台保持统一的使用方式,我选择第一种方式。

OpenAIHttpClientHandler可以在此处查看:https://github.com/Ming-jiayou/AvaloniaChat/blob/main/src/AvaloniaChat/Model/OpenAIHttpClientHandler.cs

创建Kernel的两种方式可以在此处查看:https://github.com/Ming-jiayou/AvaloniaChat/blob/main/src/AvaloniaChat/ViewModels/MainViewModel.cs

相关推荐
ai大模型中转api测评13 小时前
Claude Opus 4.7 深度拆解:自验证架构与 1M 上下文,全方位对标 GPT-5.4
人工智能·gpt·自动化·api
脑极体13 小时前
智能体落地零售,带来了哪些新可能?
大数据·人工智能·零售
摸鱼仙人~13 小时前
企业级 AI Coding 设计规范
人工智能·设计规范
咩图13 小时前
C#进程通讯-命名管道通讯
c#·命名管道·进程通讯
徐礼昭|商派软件市场负责人13 小时前
效率提升75%!AI赋能ECShopX系统开发特辑:使用Cursor、Codex、Figma等AI辅助工具高效完成商城创新功能开发
人工智能·figma
广州创科水利13 小时前
揭阳龙颈下水库除险加固:智慧监测护航,筑牢安全防线
人工智能
码云数智-大飞13 小时前
AI写单元测试的现状与挑战:覆盖率不等于有效性
人工智能
人工智能AI技术13 小时前
虚拟机基础:JVM、V8 运行机制极简科普
人工智能
和诺泰IC(-雷S-0113 小时前
现货库存TVP5158IPNPRQ1是德TI推出的一款高性能、多通道视频解码器芯片,专为安防监控、汽车电子及工业视频系统等对稳定性与图像质量要求较高的场景设计
人工智能·集成电路·电子元器件
阿里巴啦13 小时前
一个 Python 视频处理工具链实战:下载、转录、摘要、字幕、诊断全打通 (已开源)
人工智能·python·whisper·视频下载·视频处理工具