由于众所周知的原因,国内是没法直接调用 OpenAI 接口的。幸好可以白嫖 Cloudfare Workers、Vercel 等免费服务做 API 代理,我之前一直是这么用的,速度也还可以。
前两天申请的微软的 Azure OpenAI 接口通过了,立即体验了一下。它的流式响应速度比用 Cloudfare Worders 代理 OpenAI 官方接口快多了。你可以在我的这个小程序上体验一番:
下面我将演示如何开通 Azure OpenAI 服务,以及如何使用 C# 调用 Azure OpenAI 接口创建一个 Console 应用程序并实现聊天机器人功能。
开通 Azure OpenAI 服务
要开通 Azure OpenAI 服务,前提是你得有一个国际信用卡(比如 Visa 或 MasterCard),然后在 Azure 国际版(azure.com)注册一个账号。如果你不是微软 MVP,最好用公司邮箱注册,否则无法申请开通 OpenAI 服务。第一次注册并成功绑卡后,还有200美金的免费额度哦。
完成账号注册和绑卡后,在“创建资源”里找到 OpenAI 服务,根据提示点击下面这个链接填写申请表单:
或者直接访问这个链接:
https://aka.ms/oai/access
表单说明了 Azure OpenAI 服务目前只对企业或 MVP 开放,所以如果你不是 MVP 需要用公司的邮箱申请,个人 Gmail 或 Outlook 等邮箱都会被直接拒绝。
表单中涉及到公司信息部分,最好如实填写,不然也很可能被拒。填写完提交后,一般两个工作日内就会收到邮件通知。
创建 Azure OpenAI 服务
当你的申请通过后,就可以到 Azure 上创建 OpenAI 服务了。点击“创建资源”,搜索找到“OpenAI”:
点击进入,填写这一页的信息:
然后一直下一步就可以完成创建了。
服务创建好以后,还要部署一个 ChatGPT 模型。在你创建好的 OpenAI 服务中,依次点击“模型部署”-“创建”,在弹出的对话框中填写模型名称,选择 gpt-35-turbo
模型:
再到“密钥和终点”复制保存 API 要用的密钥和终结点:
创建 Console 聊天应用程序
使用 .NET 的 CLI 命令行工具或通过 IDE 创建一个 Console 应用程序:
dotnet new console -o ChatConsole
cd ChatConsole
安装两个需要用到的 Nuget 包:
dotnet add package Microsoft.Extensions.Configuration.UserSecrets
dotnet add package Azure.AI.OpenAI --prerelease
第一个包是用来管理本地密钥的,请不要直接在代码中填写密码。第二个包是 Azure 官方的 OpenAI API 库,目前只有预览版。
安装好后,通过 user-secrets
添加好下面三个配置,分别是上面创建好的终结点、密钥和模型名称:
dotnet user-secrets init
dotnet user-secrets set Azure:OpenAI:Endpoint [YOUR_AZURE_OPENAI_ENDPOINT]
dotnet user-secrets set Azure:OpenAI:ApiKey [YOUR_AZURE_OPENAI_APIKEY]
dotnet user-secrets set Azure:OpenAI:ModelName [YOUR_MODEL_DEPLOYMENT]
实现聊天功能有两种方式。一种是非流式响应,即一次性返回所有文字;另一种是流式响应,即一个字或几个字地返回,是最常用的方式。流式响应的好处是第一时间响应用户请求,在用户阅读的同时逐渐响应后面的内容,体验更佳。这两种方式的实现,请参考 Azure OpenAI API 文档:
https://learn.microsoft.com/en-us/azure/cognitive-services/openai/chatgpt-quickstart
下面以流式响应为例,实现一个 Console 版本的聊天机器人。编辑 Program.cs
文件,完整参考代码如下:
using Azure;
using Azure.AI.OpenAI;
using Microsoft.Extensions.Configuration;
using System.Text;
Console.OutputEncoding = Encoding.UTF8;
var configuration = new ConfigurationBuilder()
.AddUserSecrets<Program>()
.Build();
var apiKey = configuration["Azure:OpenAI:ApiKey"];
var endpoint = configuration["Azure:OpenAI:Endpoint"];
var modelName = configuration["Azure:OpenAI:ModelName"];
var client = new OpenAIClient(new Uri(endpoint), new AzureKeyCredential(apiKey));
var completionsOptions = new ChatCompletionsOptions
{
Messages =
{
new ChatMessage(ChatRole.System, "你是一个温柔的女生,擅长用理性的语言鼓励和引导人,对情绪低落的人进行劝慰。温柔一点,口语化一些。"),
new ChatMessage(ChatRole.User, "你好"),
}
};
while (true)
{
Console.WriteLine();
Console.Write("她: ");
var completionsResponse = await client.GetChatCompletionsStreamingAsync(
modelName,
completionsOptions
);
var resonseText = new StringBuilder();
await foreach (var choice in completionsResponse.Value.GetChoicesStreaming())
{
await foreach (var message in choice.GetMessageStreaming())
{
resonseText.Append(message.Content);
Console.Write(message.Content);
await Task.Delay(TimeSpan.FromMilliseconds(100));
}
}
completionsOptions.Messages.Add(new ChatMessage(ChatRole.Assistant, resonseText.ToString()));
Console.WriteLine();
Console.WriteLine();
Console.Write("我: ");
var userMessage = Console.ReadLine();
completionsOptions.Messages.Add(new ChatMessage(ChatRole.User, userMessage));
}
由于 Azure OpenAI 的响应速度非常快,为了模拟打字效果特意加了一点延迟。使用 dot run
运行效果如下:
总结
本文介绍了如何使用 Azure OpenAI 和 C# 创建聊天机器人。由于国内无法直接访问 OpenAI 接口,但可以通过 Cloudfare Workers 等做代理,但使用微软的 Azure OpenAI 服务可以有更快的响应体验。我介绍了如何在 Azure 中注册和创建 Azure OpenAI 服务,以及如何在服务中部署 ChatGPT 模型。接着,我演示了如何使用 .NET CLI 创建控制台应用程序,并添加相关配置。最后,我使用 C# 代码演示如何调用 Azure OpenAI 接口实现一个 Console 聊天机器人。