.NET搭建OpenAI ChatGPT服务端 搭建教程

使用.NET快速搭建一个 ChatGPT服务端 ,开放的OpenAI API

微信上大家玩 聊天机器人玩的不亦乐乎;不过随着ChatGPT被wx封杀,在wx中使用微信聊天机器人有可能导致封号的风险。不想每次都去OpenAI官网上使用ChatGPT ,不如自己搭建一个服务来本地调用 ChatGPT 毕竟OpenAI的API是对外开放的。

官网上面聊天对话有局限性,回复的内容比较长,就可能导致超过一定时间以后,变成请求超时之类的异常;而通过API直接访问,可以避免这个情况发生。

下面是官方的一些资料,动手自己搭建一个ChatGPT服务端,也方便给别人提供服务。

官网文档地址:https://beta.openai.com/docs/introduction

如果不知道怎么注册OpenAI账号,可以参考:

国外接码平台 SMS-Activate 注册 ChatGPT 详细指南,ChatGPT注册百分百成功!

搭建 ChatGPT服务端

首先新建一个webapi服务程序

使用.NET快速搭建一个 ChatGPT服务端 ,开放的OpenAI API

这里使用的是.NET6,大家也可以自己选择自己喜欢的环境,问题都不大。为了方便阅读,我选择了使用控制器和启用OpenAPI支持(swagger)。

使用.NET快速搭建一个 ChatGPT服务端 ,开放的OpenAI API

创建好以后,在program里面,添加HttpClient服务的注册,用来访问openai的api会用到。

使用.NET快速搭建一个 ChatGPT服务端 ,开放的OpenAI API

新建一个控制器,就叫 RobotController,用来提供webapi接口做测试使用。

使用.NET快速搭建一个 ChatGPT服务端 ,开放的OpenAI API

在新建的控制器里面,做点最初的准备,例如对IHttpClientFactory注入进来备用。

使用.NET快速搭建一个 ChatGPT服务端 ,开放的OpenAI API

官网上有一些资料,例如text-davinci-003模型的最大tokens是4000,所以后面有个请求参数的部分,不能超过这个数。

使用.NET快速搭建一个 ChatGPT服务端 ,开放的OpenAI API

 

这个是一个参数建议,把temperature设为0.9f,把top_p设为1. 按照文档的解释,temperature的值会影响回答的内容的一些特性,例如可能设计不友好的回复的内容的比重等。

使用.NET快速搭建一个 ChatGPT服务端 ,开放的OpenAI API

我们做个通用的请求实体类,用来当作访问我们提供的webapi接口所需的参数信息。三个信息比较重要的,当作参数,可以进行微调,例如文档建议的temp为0.9f,max tokens最大为4000,我们可以设为其他的值进行微调,等等。而message字段就是我们本身的请求参数,用来和机器人对话使用的。

使用.NET快速搭建一个 ChatGPT服务端 ,开放的OpenAI API

然后是返回体,这个格式是解析openai的返回值进行配置的,大家也可以随意参考,或者不做解析直接返回字符串也是OK的,反正是一串Json数据,问题不大。

使用.NET快速搭建一个 ChatGPT服务端 ,开放的OpenAI API

然后对刚才的Call方法做个完善,大体内容如下所示。其中,openaiKey是我个人的key,所以为了隐私泄露,我稍微打了马赛克,希望理解。其他代码内容,可以直接看截图代码。

使用.NET快速搭建一个 ChatGPT服务端 ,开放的OpenAI API

最后,启动服务程序,进入到swagger里面进行调用接口。例如,message字段我传的 “帮我写一个C#版本的Hello World”,得到的返回值体里面,位于choises[]数组的第一条数据,text就是机器人回复的内容。

使用.NET快速搭建一个 ChatGPT服务端 ,开放的OpenAI API

以上只是一个简单的写法,大家可以根据自己需要进行拓展或者改造。比如说,用已有的key和规律,写个其他语言的聊天服务,或者写个聊天客户端进行访问,等等,一切皆有可能。或者微信被封杀了,那就可以尝试自己搭建一个服务来间接继续实现某些APP的智能聊天服务等等。

ChatGPT服务端下载:https://www.mediafire.com/file/zfhax9qcbjzooq3/RobotServer.zip/file

本文博客原始链接为:https://www.cnblogs.com/weskynet/p/16987108.html

评分

3 评论

留下评论

您的电子邮箱地址不会被公开。 必填项已用 * 标注