一个功能完整的闲鱼管理系统,采用现代化的技术架构,支持多用户、多账号管理,具备智能回复、自动发货、自动确认发货、商品管理等企业级功能。系统基于Python异步编程,使用FastAPI提供RESTful API,SQLite数据库存储,支持Docker一键部署。
⚠️ 重要提示:本项目仅供学习研究使用,严禁商业用途!使用前请仔细阅读版权声明。
- 后端框架: FastAPI + Uvicorn + Python 3.11+ 异步编程
- 数据库: SQLite 3 + 多用户数据隔离 + 自动迁移
- 前端: Bootstrap 5 + Vanilla JavaScript + Chart.js + 响应式设计
- 通信协议: WebSocket + SSE + RESTful API + 实时通信
- 自动化能力: Playwright + DrissionPage + 浏览器自动化
- 部署方式: Docker + Docker Compose + Nginx(可选)+ 一键部署
- 日志系统: Loguru + 文件轮转 + 实时收集
- 安全认证: Bearer Token + 图形验证码 + 邮箱验证 + 权限控制
- 模块化架构: 按账号、订单、发货、通知、日志等模块拆分,易于维护和扩展
- 异步处理: 基于 asyncio 的高性能异步处理
- 多用户隔离: 完整的数据隔离和权限控制
- 容器化部署: Docker 容器化部署,支持一键启动
- 实时监控: WebSocket + SSE 实时通信和状态监控
- 稳定性保障: 自动重连、异常恢复、自动迁移、日志轮转
- 用户注册登录 - 支持邮箱验证码注册、用户名/邮箱登录和图形验证码保护
- 数据完全隔离 - 每个用户的数据独立存储,互不干扰
- 权限管理 - 严格的用户权限控制和 Bearer Token 认证
- 安全保护 - 防暴力破解、会话管理、安全日志
- 日期校验 - 核心滑块验证模块包含日期有效性校验
- 多账号支持 - 每个用户可管理多个闲鱼账号
- 独立运行 - 每个账号独立启用、停用和刷新
- 实时状态 - 账号连接状态和运行配置可实时查看
- 账号维护 - 支持 Cookie、账密、备注等信息管理
- 一键擦亮 - 支持在账号列表中一键批量擦亮当前在售商品
- 定时擦亮 - 支持按账号配置每日执行时段与随机延迟,自动完成商品擦亮
- 关键词匹配 - 支持通用关键词和商品专属关键词回复
- 指定商品回复 - 支持为特定商品设置专门回复内容
- 批量导入导出 - 支持 Excel 格式的关键词批量导入导出
- AI智能回复 - 支持上下文理解和多种兼容模型接口
- 图片关键词 - 支持图片关键词和图片自动发送
- 优先级策略 - 指定商品回复 > 商品专用关键词 > 通用关键词 > 默认回复 > AI回复
- 智能匹配 - 基于商品信息自动匹配发货规则
- 多规格支持 - 支持同一商品的不同规格自动匹配
- 延时发货 - 支持设置发货延时时间
- 多种触发 - 支持付款消息、小刀卡片等触发条件
- 防重复处理 - 智能防重复发货和防重复确认
- 多种发货方式 - 支持文字、批量数据、API、图片等发货方式
- 发货统计 - 完整的发货记录和统计功能
- 自动收集 - 消息触发时自动收集商品信息
- 商品详情 - 支持获取、查看和编辑商品详情
- 多规格配置 - 支持多规格商品配置和管理
- 智能去重 - 自动去重,避免重复存储
- 后台运营 - 提供订单管理、通知渠道、消息通知和在线客服等常用功能,便于统一处理日常运营事务
- 实时日志 - 完整的操作日志记录、查看和导出
- 安全统计 - 支持登录封禁和锁定统计
- 健康检查 - 服务状态健康检查
- 系统统计 - 支持用户、账号、卡券等数据统计
- Excel导入导出 - 支持关键词数据的 Excel 导入导出
- 模板生成 - 自动生成包含示例数据的导入模板
- 批量操作 - 支持批量添加、更新关键词数据
- 数据验证 - 导入时自动验证数据格式和重复性
- 多规格卡券管理 - 支持创建和管理多规格卡券
- 发货规则管理 - 支持多规格发货规则的创建和管理
- 数据备份恢复 - 支持用户备份恢复和管理员数据库备份
- 容器化部署 - 支持 Docker / Docker Compose 持久化部署
⚡ 推荐方式:使用仓库内置的 Docker Compose 配置从源码构建并启动,和当前项目配置保持一致。
Linux / macOS
# 1. 克隆项目
git clone https://github.com/GuDong2003/xianyu-auto-reply-fix.git
cd xianyu-auto-reply-fix
# 2. 执行部署脚本
chmod +x docker-deploy.sh
./docker-deploy.sh脚本会自动检查依赖、创建目录、构建镜像并启动服务。
默认访问地址:
docker-compose.yml:http://localhost:9000docker-compose-cn.yml:http://localhost:8000
Windows
:: 1. 克隆项目
git clone https://github.com/GuDong2003/xianyu-auto-reply-fix.git
cd xianyu-auto-reply-fix
:: 2. 执行部署脚本
docker-deploy.bat默认访问地址:
docker-compose.yml:http://localhost:9000docker-compose-cn.yml:http://localhost:8000
# 1. 克隆项目
git clone https://github.com/GuDong2003/xianyu-auto-reply-fix.git
cd xianyu-auto-reply-fix
# 2. 启动服务
docker compose up -d --build
# 3. 访问系统
# http://localhost:9000# 1. 克隆项目
git clone https://github.com/GuDong2003/xianyu-auto-reply-fix.git
cd xianyu-auto-reply-fix
# 2. 启动服务
docker compose -f docker-compose-cn.yml up -d --build
# 3. 访问系统
# http://localhost:8000# 1. 克隆项目
git clone https://github.com/GuDong2003/xianyu-auto-reply-fix.git
cd xianyu-auto-reply-fix
# 2. 创建虚拟环境
python -m venv venv
source venv/bin/activate # Linux/macOS
# 或 venv\Scripts\activate # Windows
# 3. 安装依赖
pip install --upgrade pip
pip install -r requirements.txt
# 4. 安装 Playwright 浏览器
playwright install chromium
playwright install-deps chromium # 仅 Linux 需要
# 5. 启动系统
python Start.py
# 6. 访问系统
# http://localhost:8090本地运行请确保已安装 Node.js,否则
PyExecJS相关功能无法正常使用。
- Python: 3.11+
- Node.js: 16+(用于 PyExecJS 执行 JavaScript)
- 系统: Windows / Linux / macOS
- 架构: x86_64 (amd64) / ARM64 (aarch64)
- Docker: 20.10+(Docker 部署)
- Docker Compose: 2.0+(Docker 部署)
- 浏览器依赖: Playwright Chromium(本地运行需要安装)
- 资源建议: 建议 2GB+ 内存,预留 10GB+ 存储空间
支持的架构:
- ✅ linux/amd64 - Intel / AMD 处理器
- ✅ linux/arm64 - ARM64 处理器
构建方式:
- ✅ 提供
build-multi-arch.sh多架构构建脚本 - ✅ 支持使用 Docker Buildx 构建 amd64 / arm64 镜像
- ✅ Docker 部署和本地运行可在对应架构环境中使用
说明:
- 当前仓库未包含 GitHub Actions 自动构建配置
- 镜像仓库地址请以实际发布情况为准
系统实际会读取的环境变量主要包括:
# Web 服务
API_HOST=0.0.0.0
API_PORT=8090
# 数据存储
DB_PATH=/app/data/xianyu_data.db
# SQL 日志
SQL_LOG_ENABLED=true
SQL_LOG_LEVEL=INFO
# 敏感信息加密
SECRET_ENCRYPTION_KEY=your-secret-key
# 兼容旧单账号模式(可选)
COOKIES_STR=your_cookie_string
# Docker 图形模式(可选)
USE_XVFB=true
ENABLE_HEADFUL=true
ENABLE_VNC=false
DISPLAY=:99其他运行参数(如 WebSocket、心跳、自动回复等)主要在
global_config.yml和 Web 管理界面中配置。
当前仓库的 GitHub Actions 会在 push 到 main 后读取 static/version.txt。如果该版本对应的 Release 还不存在,则会自动生成 update_files.json 并创建同名 Release。
自动纳入热更新清单的文件:
- 任意目录下的
.py文件 - 任意目录下的
.html文件 static/目录下的静态资源,例如.js、.css、.txt、.json、图片和字体文件static/目录下的前端源码文件,例如.ts、.tsx、.jsx、.vue
默认排除的内容:
- 用户配置和运行时目录,例如
global_config.yml、data/、logs/、browser_data/、update_backup/、venv/ - 发布和部署文件,例如
.github/、Dockerfile*、docker-compose*.yml、nginx/ - 文档、脚本、数据库和缓存文件,例如
.md、.sh、.sql
建议的发版步骤:
- 修改代码或新增需要热更新的文件
- 更新
static/version.txt为新的版本号 - 执行
python3 release_precheck.py,检查是否存在删文件、改名、未跟踪文件或忘记升级版本号的情况 - 提交并
push到main - 等待 Action 自动生成 Release 和
update_files.json
热更新在覆盖和新增文件之外,还支持通过 manifest 的 deleted_files 清理旧文件。删除前会先备份原文件,再执行清理。
部署完成后,您可以通过以下方式访问系统:
- Web管理界面:
- Docker Compose 默认配置: http://localhost:9000
- Docker Compose 国内配置: http://localhost:8000
- 本地运行: http://localhost:8090
- 默认管理员账号(首次初始化且未自定义密码时):
- 用户名:
admin - 密码:
admin123
- 用户名:
- API文档:
- Docker Compose 默认配置: http://localhost:9000/docs
- Docker Compose 国内配置: http://localhost:8000/docs
- 本地运行: http://localhost:8090/docs
- 健康检查:
- Docker Compose 默认配置: http://localhost:9000/health
- Docker Compose 国内配置: http://localhost:8000/health
- 本地运行: http://localhost:8090/health
⚠️ 安全提示:首次登录后请立即修改默认密码!
- 若系统已开启注册功能,可访问登录页或注册页(如本地运行使用
http://localhost:8090/register.html) - 填写用户信息,完成邮箱验证
- 根据系统配置完成图形验证码校验
- 登录系统后进入主界面
- 进入账号管理,添加新账号
- 输入账号 ID 和 Cookie 信息
- 可按需配置用户名、密码、备注和显示浏览器
- 保存后即可启用或刷新账号
- 在账号管理页可直接执行一键擦亮,批量处理当前账号在售商品
- 可按账号配置每日定时擦亮任务,支持执行时段和随机延迟
- 关键词回复:设置通用关键词和商品专属关键词
- AI回复:配置兼容模型接口启用智能回复
- 默认回复:设置未匹配时的默认回复
- 指定商品回复:为特定商品设置专门回复内容
- 添加卡券和发货规则,配置商品与发货内容的匹配关系
- 支持文本、批量数据、API、图片等发货方式
- 系统检测到付款消息或小刀卡片后自动触发发货流程
本项目提供了一个油猴用户脚本,可为闲鱼官网聊天页面添加暗色模式支持。
安装步骤:
- 安装油猴扩展(Tampermonkey)到浏览器
- 打开
static/userscripts/goofish-dark-mode.user.js - 在油猴扩展中创建新脚本并粘贴保存
- 访问闲鱼聊天页面后即可生效
功能特性:
- 支持开启 / 关闭 / 跟随系统三种模式
- 支持通过油猴菜单快速切换状态
- 提供适配聊天界面的暗色风格
┌─────────────────────────────────────────┐
│ Web 界面 (FastAPI + Static) │
│ 用户管理 + 功能界面 │
└───────────────────┬─────────────────────┘
│
┌───────────────────▼─────────────────────┐
│ CookieManager │
│ 多账号任务与状态管理 │
└───────────────────┬─────────────────────┘
│
┌───────────────────▼─────────────────────┐
│ XianyuLive (多实例) │
│ WebSocket 连接 + 消息处理 │
└──────────────┬──────────────┬───────────┘
│ │
┌──────────────▼───────┐ ┌────▼──────────────┐
│ AIReplyEngine │ │ FileLogCollector │
│ AI 回复与上下文 │ │ 实时日志与统计 │
└──────────────┬───────┘ └────┬──────────────┘
│ │
┌──────────────▼──────────────▼───────────┐
│ SQLite 数据库 │
│ 用户数据 + 商品信息 + 配置数据 │
└─────────────────────────────────────────┘
global_config.yml 包含详细的系统配置,支持:
- WebSocket连接参数
- API接口配置
- 自动回复设置
- 商品管理配置
- 日志配置等
- 实时日志:Web界面查看实时系统日志
- 日志文件:
logs/目录下的按日期分割的日志文件 - 日志级别:支持DEBUG、INFO、WARNING、ERROR级别
欢迎为项目做出贡献!您可以通过以下方式参与:
- 在 GitHub Issues 中报告Bug
- 提出新功能建议和改进意见
- 分享使用经验和最佳实践
- Fork 项目到您的GitHub账号
- 创建功能分支:
git checkout -b feature/your-feature - 提交更改:
git commit -am 'Add some feature' - 推送分支:
git push origin feature/your-feature - 提交 Pull Request
- Docker Compose:修改
docker-compose.yml或docker-compose-cn.yml中的端口映射 - 本地运行:修改
API_PORT环境变量,或调整global_config.yml中的AUTO_REPLY.api.port
检查 data/ 目录和数据库文件权限,确保应用有读写权限;如使用自定义路径,确认 DB_PATH 配置正确。
检查网络和防火墙设置,并确认闲鱼账号 Cookie 仍然有效。
如果遇到 bad interpreter 错误,说明脚本行结束符格式不正确:
sed -i 's/\r$//' docker-deploy.sh
chmod +x docker-deploy.sh
./docker-deploy.sh或直接使用:
bash docker-deploy.sh如果遇到 exec /app/entrypoint.sh: no such file or directory 错误:
docker compose down
docker compose build --no-cache
docker compose up -dWindows 用户建议直接使用批处理脚本:
docker-deploy.bat- 问题反馈:通过 GitHub Issues 提交
- 功能建议:通过 GitHub Issues 提出改进建议
- 使用问题:建议先查看本文档的“常见问题”部分
- xianyu-auto-reply - 提供了原始项目基础与二次开发起点
- XianYuApis - 提供了闲鱼 API 接口的技术参考
- XianyuAutoAgent - 提供了自动化处理的实现思路
- myfish - 提供了扫码登录的实现思路
- syunnrai123 - 为当前项目的滑块处理方案提供思路与参考
- Mangor2021 - 为项目开发与改进提供了实际贡献
- 82762294 - 为项目开发与改进提供了实际贡献
本项目基于原项目整理和修复,仅供学习与研究使用,请勿用于商业用途或任何违法违规场景。
- 禁止商业使用 - 不得将本项目或其衍生内容用于商业用途
- 禁止违法使用 - 不得将本项目用于任何违法违规活动
- 禁止滥用服务 - 不得利用本项目进行骚扰、欺诈或其他不当行为
- 保留来源信息 - 使用、修改或分发时请保留原项目来源说明
- 标注修改内容 - 如基于本项目进行了修改,建议明确标注修改部分
- 自行承担风险 - 使用者需自行承担部署、配置和运行风险
- 遵守当地法规 - 使用者应确保实际用途符合当地法律法规和平台规则
- 原项目:
zhinianboke-new/xianyu-auto-reply - 当前仓库:
GuDong2003/xianyu-auto-reply-fix
本项目按“现状”提供,不提供任何明示或暗示的保证;因使用本项目产生的风险、损失或责任,由使用者自行承担。