如何将AI助手接入微信(打开ai手机助手)
wptr33 2025-05-08 21:37 133 浏览
Dify平台搭建好后就可以创建各种应用,如聊天助手、文本生成、Agent、工作流等,那这些AI助手我们能不能分享给朋友使用,如接入微信、企微等?
工具介绍
- DifyOnWeCha
DifyOnWeChat 是一个开源项目,Dify on WeChat是 ChatGPT on WeChat的下游分支,额外
实现了对接Dify API,支持Dify聊天助手、支持Agent调用工具和知识库,支持Dify工作流,允
许用户在微信上快速部署和运行聊天助手应用。
Cpolar是一款体积小巧但功能强大的内网穿透工具,适用于各种环境和应用场景,能够
帮助用户实现内网与公网之间的无缝连接。
- FRP
FRP是一个快速的反向代理工具,允许将位于NAT或防火墙后面的本地服务器暴露到互
联网上。它支持TCP和UDP协议,以及HTTP和HTTPS协议,使得请求可以通过域名转
发到内部服务。
Cpolar与FRP差异
Cpolar和FRP都是用于内网穿透的工具,Cpolar适用于需要安全地将内网服务暴露至公
网的场景,特别适合开发调试阶段,因为可以将本地内网服务器的端口映射为公网地址
端口,FRP适用于需要高性能内网穿透的场景,特别是在需要通过反向代理进行复杂路
由和负载均衡的情况下。
DifyOnWeChat安装--Docker模式
- 验证Dify助手可用
通过http://127.0.0.1打开Dify,进入到配置好的AI助手,打开并确认是否运行正常。
- 生成DifyAPI密钥与API服务器地址
创建API密钥。注意创建API密钥时,一定要及时保存,因为它后续将无法完全显示。另外建议你尽量一个密钥只用于一个渠道,这样即便密钥不小心被泄露,或遇到安全风险,直接把密钥删除掉就可以了。
- 下载DifyOnWeChat
- 使用git通过命令行直接从GitHub下载文件。
git下载更加高效,在更新版本时,git只更新必要文件,而不是每次都把所有的下载一遍。
- 直接下载zip文件
打开Github(网址:github.com),找到对应的DifyOnWeChat工具,点击“download zip”按钮下载并解压缩。
打开终端执行指令:docker compose up -d
- 验证安装是否成功
验证安装是否成功的办法和dify相同,你可以打开Docker Desktop界面,查看dify-on-wechat容器是否正常运行。
接下来,你就可以在终端执行命令,来显示二维码,通过微信登录后,即可完成与微信的连接,运行:
docker logs -f dify-on-wechat--是一个用于实时跟踪容器输出的Docker命令。
6、验证
接下来,你就可以在终端执行命令,来显示二维码,通过微信登录后,即可完成与微信的连接
DifyOnWeChat安装--Python模式
由于目前国内大量的Docker镜像失效,可能会导致你下载Docker镜像时发现速度很慢,或者根本无法下载。你可以选择第二种直接部署的方式,在Windows上安装DifyOnWeChat。为了让DifyOnWeChat能够像运行在Docker环境一样正常使用,你需要为Windows搭建它的运行环境。这个过程包括安装Python、建立虚拟环境、激活虚拟环境、安装依赖的第三方软件包、运行DifyOnWeChat主程序五个步骤。
1、安装Python并创建虚拟环境,安装Python(网址:https://www.python.org/)。如果你的Windows中已经安装了Python,可以通过Python/version查看它的版本号。特别提醒如果你的电脑系统是win7之前的版本,需要找到更早的python版本去下载。
2、为Python创建虚拟环境,虚拟环境保存在一个叫做venv的文件夹,为了你的目录整洁,我一般习惯于在项目的文件夹内创建该文件夹。因此我首先进入d:\software\dify-on-wechat文件夹后,运行:python -m venv venv
3、激活虚拟环境,运行:
.\venv\Scripts\Activate.ps1
这样后面在这个终端下安装的所有软件包都会放在venv文件夹中,避免污染Windows的其他文件夹。当你需要卸载DifyOnWeChat时,可以将这一文件夹直接删除掉。
4、部署DifyOnWeChat运行所必须的依赖软件包
pip3 install -r .\requirements.txt -i https://mirrors.aliyun.com/pypi/simple
这条命令的含义是从requirements.txt文件中找到DifyOnWeChat所必须得软件包名称和版本,通过python的包管理命令pip3 进行安装。
如果下载过慢,可以使用国内的镜像网站进行下载:-i
https://mirrors.aliyun.com/pypi/simple
5、配置文件config.json
"dify_api_base": "http://127.0.0.1/v1",
"dify_api_key": "你的Dify密钥",
"dify_app_type": "chatbot",
"channel_type": "wx",
"model": "dify",
"single_chat_prefix": [""],
"single_chat_reply_prefix": "",
"group_chat_prefix": ["@bot"],
"group_name_white_list": ["ALL_GROUP"],
"accept_friend_commands": ["加好友"],
"group_exit_msg": "退群聊通知文案"
6、运行DifyOnWeChat的主程序,并验证:
python app.py
通过Cpolar为Dify创建域名
在Dify所在的Windows安装Cpolar建立到服务器的隧道,请求Cpolar服务时,会将请求转发到Dify。
- 下载Cpolar
通过官方网站“
https://www.cpolar.com/download”根据你的操作系统版本下载Cpolar。
- 安装Cpolar并注册用户和配置隧道
安装后注册用户选择套餐登录后如下。
在Cpolar的本地管理页面,通过左侧的隧道管理-隧道列表可以查看当前支持的隧道,可以通
过右侧的操作按钮,将你的Dify端口通过隧道发布到Cpolar服务器。
接下来回到主界面左侧-点击状态=在线隧道列表-查看到Dify隧道对应的公网地址,你在公司就可以通过公网地址访问到家里的Dify。如上图的公网"
http://56e786a9.r3.cpolar.cn"。
- 保留二级子域名(可选)
Cpolar安装简单,但是免费用户的公网地址(即域名)每隔24小时就会自动改变。如果访问失败,你需要通过官方网站的“状态”页面人工查看并更新地址。
你也可以通过预留菜单-保留二级子域名,来生成固定的域名,点击参考教程-设置地区、二级域名、描述三个设置项,完成后点击保留即可。注意,此功能属于付费功能,可以按需配置。
企业级:如何通过FRP实现域名解析?
到此为止,已经完成了前面的部署,获得了一个具有域名的AI助手。但如果是企业用户,希望有更加稳定的网络环境和固定的域名,那么可以继续进行以下操作。请注意,企业级的部署属于高阶课程,更适合专业的技术从业者,由于比较复杂,在这只说明下原理,具体的配置可自动去研究。
- 利用frp实现tcp隧道,将内网的Dify发布到公有云主机。
- 利用公有云域名解析和公网ip的固定性,实现稳定的内网Dify发布到外网功能。
接入微信并测试
打开DifyOnWeChat安装目录下的docker.yml文件,配置上DifyAPI密钥与API服务器地址。
修改配置后,需要重新启动dify-on-wechat容器应用。
通过微信扫码登录dify-on-wechat应用
然后给微信机器人发送消息,进行测试
微信机器人的回复与在Dify测试页面上的回复一致,终于更进一步。
Dify提供给他人访问的两种方式,一种是通过即时通讯工具,比如微信、钉钉、飞书进行访问。其中DifyOnWechat的设置是最简单的。使用其他即时通讯工具进行对接时,方法也都比较相似。如果只是共享一个助手,使用微信调用Dify的API会更方便。如果希望共享多个助手,并进行一些设置,那建议使用域名和内网穿透的方式。
后续我们可以把Dify工作流编排应用接入了个人微信,可以向知识库中导入相关的文档,就能让微信机器人为你解答更多的问题。
相关推荐
- 高性能并发队列Disruptor使用详解
-
基本概念Disruptor是一个高性能的异步处理框架,是一个轻量的Java消息服务JMS,能够在无锁的情况下实现队列的并发操作Disruptor使用环形数组实现了类似队列的功能,并且是一个有界队列....
- Disruptor一个高性能队列_java高性能队列
-
Disruptor一个高性能队列前言说到队列比较熟悉的可能是ArrayBlockingQueue、LinkedBlockingQueue这两个有界队列,大多应用在线程池中使用能保证线程安全,但其安全性...
- 谈谈防御性编程_防御性策略
-
防御性编程对于程序员来说是一种良好的代码习惯,是为了保护自己的程序在不可未知的异常下,避免带来更大的破坏性崩溃,使得程序在错误发生时,依然能够云淡风轻的处理,但很多程序员入行很多年,写出的代码依然都是...
- 有人敲门,开水开了,电话响了,孩子哭了,你先顾谁?
-
前言哎呀,这种情况你肯定遇到过吧!正在家里忙活着,突然——咚咚咚有人敲门,咕噜咕噜开水开了,铃铃铃电话响了,哇哇哇孩子又哭了...我去,四件事一起来,人都懵了!你说先搞哪个?其实这跟我们写Java多线...
- 面试官:线程池如何按照core、max、queue的执行顺序去执行?
-
前言这是一个真实的面试题。前几天一个朋友在群里分享了他刚刚面试候选者时问的问题:"线程池如何按照core、max、queue的执行循序去执行?"。我们都知道线程池中代码执行顺序是:co...
- 深入剖析 Java 中线程池的多种实现方式
-
在当今高度并发的互联网软件开发领域,高效地管理和利用线程资源是提升程序性能的关键。Java作为一种广泛应用于后端开发的编程语言,为我们提供了丰富的线程池实现方式。今天,就让我们深入探讨Java中...
- 并发编程之《彻底搞懂Java线程》_java多线程并发解决方案详解
-
目录引言一、核心概念:线程是什么?...
- Redis怎么实现延时消息_redis实现延时任务
-
一句话总结Redis可通过有序集合(ZSET)实现延时消息:将消息作为value,到期时间戳作为score存入ZSET。消费者轮询用ZRANGEBYSCORE获取到期消息,配合Lua脚本保证原子性获取...
- CompletableFuture真的用对了吗?盘点它最容易被误用的5个场景
-
在Java并发编程中,CompletableFuture是处理异步任务的利器,但不少开发者在使用时踩过这些坑——线上服务突然雪崩、异常悄无声息消失、接口响应时间翻倍……本文结合真实案例,拆解5个最容易...
- 接口性能优化技巧,有点硬_接口性能瓶颈
-
背景我负责的系统到2021年初完成了功能上的建设,开始进入到推广阶段。随着推广的逐步深入,收到了很多好评的同时也收到了很多对性能的吐槽。刚刚收到吐槽的时候,我们的心情是这样的:...
- 禁止使用这5个Java类,每一个背后都有一段"血泪史"
-
某电商平台的支付系统突然报警:大量订单状态异常。排查日志发现,同一笔订单被重复支付了三次。事后复盘显示,罪魁祸首竟是一行看似无害的SimpleDateFormat代码。在Java开发中,这类因使用不安...
- 无锁队列Disruptor原理解析_无锁队列实现原理
-
队列比较队列...
- Java并发队列与容器_java 并发队列
-
【前言:无论是大数据从业人员还是Java从业人员,掌握Java高并发和多线程是必备技能之一。本文主要阐述Java并发包下的阻塞队列和并发容器,其实研读过大数据相关技术如Spark、Storm等源码的,...
- 线程池工具及拒绝策略的使用_线程池处理策略
-
线程池的拒绝策略若线程池中的核心线程数被用完且阻塞队列已排满,则此时线程池的资源已耗尽,线程池将没有足够的线程资源执行新的任务。为了保证操作系统的安全,线程池将通过拒绝策略处理新添加的线程任务。...
- 【面试题精讲】ArrayBlockingQueue 和 LinkedBlockingQueue 区别?
-
有的时候博客内容会有变动,首发博客是最新的,其他博客地址可能会未同步,认准...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
如何将AI助手接入微信(打开ai手机助手)
-
Java面试必考问题:什么是乐观锁与悲观锁
-
SparkSQL——DataFrame的创建与使用
-
redission YYDS spring boot redission 使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)