Skip to content

luoqiz/wcf-client-rust

Repository files navigation

WeChatFerry HTTP 客户端(基于 Rust)

又一个 WeChatFerry 的 HTTP 客户端。🙋 FAQ

免责声明【必读】

本工具仅供学习和技术研究使用,不得用于任何商业或非法行为,否则后果自负。

本工具的作者不对本工具的安全性、完整性、可靠性、有效性、正确性或适用性做任何明示或暗示的保证,也不对本工具的使用或滥用造成的任何直接或间接的损失、责任、索赔、要求或诉讼承担任何责任。

本工具的作者保留随时修改、更新、删除或终止本工具的权利,无需事先通知或承担任何义务。

本工具的使用者应遵守相关法律法规,尊重微信的版权和隐私,不得侵犯微信或其他第三方的合法权益,不得从事任何违法或不道德的行为。

本工具的使用者在下载、安装、运行或使用本工具时,即表示已阅读并同意本免责声明。如有异议,请立即停止使用本工具,并删除所有相关文件。

点击查看功能清单
  • 检查登录状态
  • 查询登录账号 wxid
  • 获取登录账号信息
  • 获取通信录
  • 列出所有可查询数据库
  • 查询数据库的表信息
  • 查询消息类型映射表
  • 接收消息
  • 刷新朋友圈
  • 发送文本消息
  • 发送图片消息
  • 发送文件消息
  • 发送卡片消息
  • 发送拍一拍消息
  • 转发消息
  • 保存语音
  • 下载图片
  • 某功能
  • 查询 SQL
  • 通过好友申请
  • 添加群成员
  • 邀请群成员(群人数超过一定数量只能邀请)
  • 删除群成员
  • 撤回消息

界面预览

image image image image image

快速开始

ℹ️ 如果跑过机器人,先将机器人停止,然后退出微信,再开始,以避免奇奇怪怪的问题。

回调示例

如果不懂回调,玩这个其实不是很合适。尽管如此,这里还是提供一个示例。

#! /usr/bin/env python3
# -*- coding: utf-8 -*-

import uvicorn
from fastapi import Body, FastAPI
from pydantic import BaseModel


class Msg(BaseModel):
    is_self: bool
    is_group: bool
    id: int
    type: int
    ts: int
    roomid: str
    content: str
    sender: str
    sign: str
    thumb: str
    extra: str
    xml: str


def msg_cb(msg: Msg = Body(description="微信消息")):
    """示例回调方法,简单打印消息"""
    print(f"收到消息:{msg}")
    return {"status": 0, "message": "成功"}


if __name__ == "__main__":
    app = FastAPI()
    app.add_api_route("/callback", msg_cb, methods=["POST"])
    uvicorn.run(app, host="0.0.0.0", port=8000)

版本更新

v39.0.14.0(2024.02.18)

  • 大量优化
点击查看更多

v39.0.12.4(2024.02.13)

  • 撤回消息
  • 实现单实例
  • 其他功能优化

v39.0.12.3(2024.02.08)

  • 通过好友申请
  • 添加群成员
  • 邀请群成员(群人数超过一定数量只能邀请)
  • 删除群成员

v39.0.12.2(2024.02.08)

  • 发送文件消息
  • 发送卡片消息
  • 发送拍一拍消息
  • 转发消息
  • 保存语音
  • 下载图片
  • 某功能
  • 查询 SQL

v39.0.12.1(2024.02.06)

  • 发送图片消息

v39.0.12.0 (2024.02.05)

  • 检查登录状态
  • 查询登录账号 wxid
  • 获取登录账号信息
  • 获取通信录
  • 列出所有可查询数据库
  • 查询数据库的表信息
  • 查询消息类型映射表
  • 接收消息
  • 刷新朋友圈
  • 发送文本消息
碲矿 赞赏
后台回复 WCF 加群交流 如果你觉得有用

一起开发(🚫非开发者不用往下看)

搭建开发环境

安装 Rustup

访问 Rust 官方网站,下载并运行 Rustup 的安装程序。 下载地址: text

在安装过程中,选择默认配置即可,这将安装最新稳定版本的 Rust,包括 rustccargorustup 自身。

安装 node,npm,pnpm

访问 Node 官方网站,下载并运行 Node.js 的安装程序。 下载地址: text

更换 npm 软件源,并安装 pnpm

npm config set registry https://registry.npmmirror.com

npm i -g pnpm

安装 Protoc

下载适用于 Windows 的 protoc 二进制文件。 下载地址: text

解压到一个目录,并将该目录添加到你的系统环境变量 PATH 中,这样你就可以在命令行中直接运行 protoc 命令了。

安装 visual studio 的桌面开发环境

下载适用于 Windows 的桌面开发环境(社区版即可,企业版自己解决)。 下载地址: text

安装 c++ 桌面开发环境, cmake 编译环境

主要配置

验证安装

打开命令行或终端,运行以下命令以确认 Rust 和 Cargo 已正确安装:

rustc --version
cargo --version
protoc --version

当前项目开发环境如下:

rustc 1.75.0 (82e1608df 2023-12-21)
cargo 1.75.0 (1d8b05cdd 2023-11-20)
libprotoc 22.2

调试运行

# 启动运行
pnpm tauri dev

验证

点击 启动,然后访问 http://localhost:10010/swagger/

定制 Logo

  1. 找一张 logo 图片 your_path/logo.png(1024*1024 的 PNG 图片)
  2. 通过命令重新生成:cargo tauri icon your_path/logo.png