.net做一个基于ChatGpt的微信机器人吧~[全教程]
最近这个ChatGPT很火啊,看了B站上很多视频,自己非常手痒,高低自己得整一个啊,很多人都是把ChatGPT和微信结合在一起,正巧我是Wechaty框架的.net sdk贡献者,这不是一应俱全了吗?
ChatGPT是啥?
先了解GTP,摘自官网的一段话“A set of models that can understand and generate natural language”,其实,就是一个自然语言处理的模型。所以ChatGPT顾名思义就是基于GPT3的一个聊天AI。
但是想让他做苦力帮忙写代码的话所需要的其实不是这个模型,而是Codex这个模型,按照官网所说“Most capable Codex model. Particularly good at translating natural language to code. In addition to completing code, also supports inserting completions within code.”。真的是碉堡了!
准备
第一步:注册OpenAI账号
因为对大陆以及中国香港地区不开放,所以我们需要小小的科学一下。
来一个我就是参照着申请账号的园子的文章:
https://www.cnblogs.com/chatgpt/p/how-to-register-chatgpt-in-china.html
当然手机那里可以淘宝找,几块钱就能帮忙注册手机,账号里面默认还有18美元余额。
注意点:如果搭建了科学还是提示不对你的国家提供服务的话,尝试清空浏览器缓存或者打开浏览器的无痕窗口。Chrome默认在右上角三个点打开就能找到“打开新的无痕式窗口”。
第二步:Wechaty token
由于本人是wechaty的贡献者,所以是有一年免费的token的。
申请网址:http://pad-local.com/
只要注册一个账号就有七天免费的token,当然听说wechaty官网可以搞一个15天的试用。
大家如果只是体验的话,可以轮流搞几个免费token,毕竟价格实在太不美丽了,大款可以直接付款买~
第三步: 搭建Wechaty网关
这边推荐用docker安装wechaty gateway
Docker直接输入命令:
docker pull wechaty/wechaty
拉完镜像后直接运行
docker run -ti \
-d \
--restart = always \
--name wechaty_gateway \
--rm \
-e WECHATY_LOG = verbose \
-e WECHATY_PUPPET = wechaty-puppet-padlocal \
-e WECHATY_PUPPET_PADLOCAL_TOKEN = ###你申请到的wechaty token### \
-e WECHATY_PUPPET_SERVER_PORT = ###服务对外的端口### \
-e WECHATY_TOKEN = ###自己生成的token### \
-p "$WECHATY_PUPPET_SERVER_PORT:$WECHATY_PUPPET_SERVER_PORT" \
wechaty/wechaty
其中 WECHATY_TOKEN是自己生成的token,大家随便找个地方生成一个GUID就行了,但是一定要保存起来。
万事具备,直接撸代码
引用官网推荐的.net sdk
<PackageReference Include="Betalgo.OpenAI.GPT3" Version="6.6.0" />
注册OpenAI服务,并且传入app key
services.AddOpenAIService(options =>
{
options.ApiKey = openAIOptions.AppKey;
});
使用自带的方法,传入特定的模型和文本,然后发送给OpenAI,NLP作出处理后得到解析的结果。
/// <summary>
/// 对话
/// </summary>
/// <param name="question">原话</param>
/// <returns></returns>
/// <exception cref="Exception"></exception>
public async Task<CompletionCreateResponse> TalkAsync(string words)
{
if (string.IsNullOrEmpty(words))
return null;
var completionResult = await _asyncTimeoutPolicy.ExecuteAsync(async () =>
{
return await _openAIService.Completions.CreateCompletion(new CompletionCreateRequest()
{
Prompt = words,
MaxTokens = _textMaxTokens,
Temperature = _textTemperature
}, _textModel);
});
if (completionResult.Successful)
{
return completionResult;
}
else
{
var errorMsg = completionResult.Error == null ? "Unknown Error" : $"{completionResult.Error.Code}: {completionResult.Error.Message}";
throw new Exception(errorMsg);
}
}
启动Wechaty机器人,传入token和上面安装的Wechaty网关所在的终结点。
var PuppetOptions = new PuppetOptions()
{
Token = _configuration["WECHATY_PUPPET_SERVICE_TOKEN"],//上面自己生成的WECHATY_TOKEN
Endpoint = _configuration["WECHATY_PUPPET_SERVICE_ENDPOINT"]//Wechaty网关所在地址:https://ip:port
};
_bot = new Wechaty.Wechaty(PuppetOptions).Use(new QRCodeTerminalPlugin());
_bot.OnScan(OnScanLinstener);
await _bot.OnMessage(WechatyMessageEventListenerAsync).OnHeartbeat(WechatyHeartbeatEventListener).Start();
启动后,正常情况下,在控制台会出现一个微信二维码,直接掏出你的微信扫码登陆就行。
Wechaty接收信息处理事件
/// <summary>
/// 接受消息
/// </summary>
/// <param name="message"></param>
private async void WechatyMessageEventListenerAsync(Message message)
{
if (message.Self || message.Type != MessageType.Text) //来自自己的消息不回复 目前只处理文本信息
return;
try
{
if (message.Room == null || string.IsNullOrEmpty(message.Room.Id))
{
await HandleSingleCoversation(message); //私聊
}
else
{
await HandleRoomCoversation(message); //群聊
}
}
catch (Exception ex)
{
Console.WriteLine(ex);
}
}
效果截图
文本聊天
代码模式
源码,部署方式,体验一下
https://github.com/BruceQiu1996/NChatGPT
总结
在我看来GPT更像是一个知识面非常宽广可以给出非常专业的建议的知识大脑,同时他的代码库非常齐全,能够写出很多算法。
希望程序员们再接再厉,早日把我们搞没了,哈哈哈。
.net做一个基于ChatGpt的微信机器人吧~[全教程]的更多相关文章
- 扩展一个boot的插件—tooltip&做一个基于boot的表达验证
在线演示 本地下载 (代码太多请查看原文) 加班,加班加班,我爱加班··· 我已经疯了,哦也. 这次发一个刚接触boot的时候用boot做的表单验证,我们扩展一下tooltip的插件,让他可以换颜色. ...
- 使用java做一个能赚钱的微信群聊机器人(2020年基于PC端协议最新可用版)
前言 微信群机器人,主要用来管理群聊,提供类似天气查询.点歌.机器人聊天等用途. 由于微信将web端的协议封杀后,很多基于http协议的群聊机器人都失效了,所以这里使用基于PC端协议的插件来实现. 声 ...
- 手把手做一个基于vue-cli的组件库(上篇)
基于vue-cli4的ui组件库,先贴个最终效果吧,步骤有点多,准备分上下篇,上篇:如何做一个初步的组件.下篇:编写说明文档及页面优化.开工. GitHub源码地址:https://github.co ...
- 手把手做一个基于vue-cli的组件库(下篇)
基于vue-cli4的ui组件库,上篇:如何做一个初步的组件.下篇:编写说明文档及页面优化.接上篇,开工. GitHub源码地址:https://github.com/sq-github/sq-ui ...
- 一个基于thinkphp的微信授权登陆功能
共享一份基于thinkphp开发的用户授权登陆的功能代码,本实例使用thinkphp的第三方微信公众平台PHP-SDK,地址https://github.com/dodgepudding/wechat ...
- 一个基于STSdb和fastJson的磁盘/内存缓存
一个基于STSdb和fastJson的磁盘/内存缓存 需求 业务系统用的是数据库,数据量大,部分只读或相对稳定业务查询复杂,每次页面加载都要花耗不少时间(不讨论异步),觉得可以做一下高速缓存,譬如用n ...
- 一个基于ES5的vue小demo
由于现在很多vue项目都是基于ES6开发的,而我学vue的时候大多是看vue官网的API,是基于ES5的,所以对于刚接触项目的我来说要转变为项目的模块化写法确实有些挑战.因此,我打算先做一个基于ES5 ...
- UnityEditorWindow做一个TimeLine的滑动块
UnityEditorWindow做一个TimeLine的滑动块 最近在做一个基于TimeLine的动画编辑器,在制作TineLine滑动条时遇到问题,网上查了好久,试了好多GUI组件都不满意.最后在 ...
- 开源低代码平台开发实践二:从 0 构建一个基于 ER 图的低代码后端
前后端分离了! 第一次知道这个事情的时候,内心是困惑的. 前端都出去搞 SPA,SEO 们同意吗? 后来,SSR 来了. 他说:"SEO 们同意了!" 任何人的反对,都没用了,时代 ...
- 基于Unity3D 的Vuforia SDK开发基础教程
最新博客地址已转到: http://blog.csdn.net/zzlyw?viewmode=contents ------------------------------------------ ...
随机推荐
- Prometheus告警处理
在Prometheus Server中定义告警规则以及产生告警,Alertmanager组件则用于处理这些由Prometheus产生的告警.Alertmanager即Prometheus体系中告警的统 ...
- PAT (Basic Level) Practice 1029 旧键盘 分数 20
旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现.现在给出应该输入的一段文字.以及实际被输入的文字,请你列出肯定坏掉的那些键. 输入格式: 输入在 2 行中分别给出应该输入的文字.以及 ...
- nsis制作新版迅雷安装界面
终于搞出来一点名堂,不借用皮肤插件,圆角,无标题栏拖动,渐隐渐显,纯nsis代码编写,相似度大概也有95%以上了. 演示程序下载
- C#-12 转换
一 什么是转换 转换是接受一个类型的值并使用它作为另一个类型的等价值的过程. 下列代码演示了将1个short类型的值强制转换成byte类型的值. short var1 = 5; byte var2 = ...
- css三角形文本框
<style type="text/css"> .triangle{/* 三角形图片位置 */ background-image: url(img/traintop.p ...
- 微信小程序第三方授权登录
登录流程时序图: 1.调用uni.getProvider()获取服务供应商,参数service确定是选择对应的什么操作,此处选择授权登录oauth 代码如下: 2.调用登录接口uni.login(), ...
- Gson的使用与理解
当今社会下,前后端分离,不同系统的信息交互,消息队列的数据传递,微服务的不同服务之间的数据处理,越来越多地方用到了序列化.序列化作为不同系统不同服务之间的数据桥梁.那么方便快捷的序列化工具还是必要的. ...
- 使用dotnet-monitor sidecar模式 dump docker运行的dotnet程序.
前情概要 随着容器和云技术的发展, 大量的应用运行在云上的容器中, 它们的好处是毋庸置疑的, 例如极大的提高了我们的研发部署速度, 快速的扩缩容等等, 但是也存在一些小小的问题, 例如难以调试. 基于 ...
- .net core 读取appsettings.json 文件中文乱码的问题
解决办法:设置高级保存选项 第一步:在工具栏找到自定义选项 第二步:添加高级保存选项Advanced save options 第三步:在Appsettings.json页面操作
- MAUI 初体验 联合 WinForm 让家里废弃的手机当做电脑副品用起来
软件效果图 软件架构草图 效果解释:运行 winform 端后 使用 ctrl+c 先复制任何词语,然后ctrl+空格 就可以将翻译结果显示在 安卓,IOS,windows 甚至 mac 任意客户端 ...