[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-71939":3},{"id":4,"name":5,"fullName":6,"owner":7,"repo":5,"description":8,"homepage":9,"htmlUrl":10,"language":11,"languages":10,"totalLinesOfCode":10,"stars":12,"forks":13,"watchers":14,"openIssues":15,"contributorsCount":16,"subscribersCount":16,"size":16,"stars1d":17,"stars7d":18,"stars30d":19,"stars90d":16,"forks30d":16,"starsTrendScore":20,"compositeScore":21,"rankGlobal":10,"rankLanguage":10,"license":22,"archived":23,"fork":23,"defaultBranch":24,"hasWiki":25,"hasPages":25,"topics":26,"createdAt":10,"pushedAt":10,"updatedAt":40,"readmeContent":41,"aiSummary":42,"trendingCount":16,"starSnapshotCount":16,"syncStatus":43,"lastSyncTime":44,"discoverSource":45},71939,"ai-goofish-monitor","Usagi-org\u002Fai-goofish-monitor","Usagi-org","基于 Playwright 和AI实现的闲鱼多任务实时\u002F定时监控与智能分析系统，配备了功能完善的后台管理UI。帮助用户从闲鱼海量商品中，找到心仪产品。","",null,"Python",12444,1809,40,49,0,105,187,773,315,119.77,"MIT License",false,"master",true,[27,28,29,30,31,32,33,34,35,36,37,38,39],"ai","ai-assistant","ai-tools","automation","gemini","goofish","open-source","openai","playwright","tool","xian-yu","xianyu","xianyu-bot","2026-06-12 04:01:02","# 闲鱼智能监控系统\n\n[中文] ｜ [English](README_EN.md)\n\n基于 Playwright 和 AI 的闲鱼多任务实时监控，提供完整的 Web 管理界面。\n\n\n## 核心特性\n\n- **Web 可视化管理**: 任务管理、账号管理、AI 标准编辑、运行日志、结果浏览\n- **AI 驱动**: 自然语言创建任务，多模态模型深度分析商品\n- **多任务并发**: 独立配置关键词、价格、筛选条件和 AI Prompt\n- **高级筛选**: 包邮、新发布时间范围、省\u002F市\u002F区三级区域筛选\n- **即时通知**: 支持 ntfy.sh、企业微信、Bark、Telegram、Webhook等多渠道\n- **定时调度**: 支持 Cron 配置周期性任务\n- **账号与代理轮换**: 多账号管理、任务绑定账号、代理池轮换与失败重试\n- **Docker 部署**: 一键容器化部署\n\n## 截图\n\n![监控概览](static\u002Fimg.png)\n![任务管理](static\u002Fimg_1.png)\n![结果查看](static\u002Fimg_2.png)\n![通知推送](static\u002Fimg_3.png)\n\n## 🐳 Docker 部署（推荐）\n\n```bash\ngit clone https:\u002F\u002Fgithub.com\u002FUsagi-org\u002Fai-goofish-monitor && cd ai-goofish-monitor\ncp .env.example .env\nvim .env # 填写相关配置项\ndocker compose up -d\ndocker compose logs -f app\ndocker compose down\n```\n\n如果镜像无法访问或下载速度慢，可尝试使用加速：\n```bash\n\ndocker pull ghcr.nju.edu.cn\u002Fusagi-org\u002Fai-goofish:latest\ndocker tag ghcr.nju.edu.cn\u002Fusagi-org\u002Fai-goofish:latest ghcr.io\u002Fusagi-org\u002Fai-goofish:latest\ndocker compose up -d\n\n```\n\n- 默认 Web UI 地址：`http:\u002F\u002F127.0.0.1:8000`\n- Docker 镜像已内置 Chromium，无需宿主机额外安装浏览器。\n- 官方镜像地址：`ghcr.io\u002Fusagi-org\u002Fai-goofish:latest`\n- 更新镜像：`docker compose pull && docker compose up -d`\n- 如果你修改了 `.env` 中的 `SERVER_PORT`，请同步更新 `docker-compose.yaml` 里的端口映射。\n- `docker-compose.yaml` 默认会把 SQLite 主库挂载到 `.\u002Fdata:\u002Fapp\u002Fdata`，数据库文件默认为 `data\u002Fapp.sqlite3`\n- 目前默认持久化这些目录：\n    - `data\u002F`  SQLite 主存储（任务、结果、价格历史）\n    - `state\u002F`  登录状态 cookie 文件\n    - `prompts\u002F`  任务提示词\n    - `logs\u002F`  运行日志\n    - `images\u002F`  商品图片与任务临时图片目录\n    - `config.json`、`jsonl\u002F`、`price_history\u002F`  首次升级到 SQLite 时用于兼容导入的旧数据源\n\n### 数据存储与迁移\n\n- 当前在线主存储为 SQLite，默认路径 `data\u002Fapp.sqlite3`\n- 可通过环境变量 `APP_DATABASE_FILE` 自定义数据库路径；Docker 默认设置为 `\u002Fapp\u002Fdata\u002Fapp.sqlite3`\n- 应用启动时会自动建库建表，并尝试从旧的 `config.json`、`jsonl\u002F`、`price_history\u002F` 导入一次历史数据\n- `state\u002F`、`prompts\u002F`、`logs\u002F`、`images\u002F` 仍然是文件系统目录，不在 SQLite 中\n- 商品图片会临时落到 `images\u002Ftask_images_\u003Ctask_name>\u002F`，任务结束后默认会清理\n- 首次升级完成并确认 `data\u002Fapp.sqlite3` 中数据正确后，可视部署方式决定是否继续保留旧的 `config.json`、`jsonl\u002F`、`price_history\u002F` 挂载\n\n### 最少配置\n\n| 变量 | 说明 | 必填 |\n|------|------|------|\n| `OPENAI_API_KEY` | AI 模型 API Key | 是 |\n| `OPENAI_BASE_URL` | OpenAI 兼容接口地址 | 是 |\n| `OPENAI_MODEL_NAME` | 支持图片输入的模型名称 | 是 |\n| `WEB_USERNAME` \u002F `WEB_PASSWORD` | Web UI 登录账号密码，默认 `admin\u002Fadmin123` | 否 |\n\n其余配置见下方“配置说明”。\n\n\n### 第一次使用\n\n1. 打开默认 Web UI `http:\u002F\u002F127.0.0.1:8000` 并登录。\n2. 进入“闲鱼账号管理”，使用 [Chrome 扩展](https:\u002F\u002Fchromewebstore.google.com\u002Fdetail\u002Fxianyu-login-state-extrac\u002Feidlpfjiodpigmfcahkmlenhppfklcoa) 导出并粘贴闲鱼登录态 JSON。\n3. 登录态文件会保存到 `state\u002F` 目录，例如 `state\u002Facc_1.json`。\n4. 回到“任务管理”，创建任务并绑定账号后即可运行。\n\n### 创建第一个任务\n\n- `AI判断`：填写“详细需求”，提交后会弹出独立进度弹窗，后台异步生成分析标准。\n- `关键词判断`：填写关键词规则，任务会直接创建，不经过 AI 生成流程。\n- `区域筛选`：已改为省 \u002F 市 \u002F 区三级选择器，数据基于闲鱼页面抓取快照内置。\n\n\n\n## 用户使用说明\n\n\u003Cdetails>\n\u003Csummary>点击展开 Web UI 功能说明\u003C\u002Fsummary>\n\n### 任务管理\n\n- 支持 AI 创建、关键词规则、价格范围、新发布范围、区域筛选、账号绑定、定时规则。\n- AI 任务创建是后台 job 流程，提交后会打开单独的进度弹窗。\n- 区域筛选会显著缩小结果集，默认留空。\n\n### 账号管理\n\n- 支持导入、更新、删除闲鱼账号登录态。\n- 每个任务可指定账号，也可不绑定并交给系统自动选择。\n\n### 结果查看与运行日志\n\n- 结果页和导出功能现在从 SQLite 查询，不再直接扫描 `jsonl` 文件。\n- 日志页按任务展示运行过程，便于排查登录态失效、风控和 AI 调用问题。\n\n### 系统设置\n\n- 可查看系统状态、编辑 Prompt、调整代理与轮换相关配置。\n\n\u003C\u002Fdetails>\n\n\n\n## 开发者开发\n\n### 环境要求\n\n- Python 3.10+\n- Node.js + npm（本地验证 `Node v20.18.3` 可完成前端构建）\n- Playwright CLI 与 Chromium，首次运行前建议执行 `python3 -m pip install playwright && python3 -m playwright install chromium`\n- Chrome \u002F Edge 浏览器（Linux 环境也可使用 Chromium；`start.sh` 会先检查浏览器是否存在）\n\n```bash\ngit clone https:\u002F\u002Fgithub.com\u002FUsagi-org\u002Fai-goofish-monitor\ncd ai-goofish-monitor\ncp .env.example .env\n```\n\n### 一键启动\n\n```bash\nchmod +x start.sh\n.\u002Fstart.sh\n```\n\n`start.sh` 会先检查 Playwright CLI 和浏览器前置条件；在前置条件满足后自动安装项目依赖、构建前端、复制构建产物并启动后端。\n\n### 手动启动\n\n```bash\n# 后端\npython -m src.app\n# 或\nuvicorn src.app:app --host 0.0.0.0 --port 8000 --reload\n\n# 前端\ncd web-ui\nnpm install\nnpm run dev\n```\n\n- FastAPI 启动时会自动初始化 SQLite，并在首次启动时尝试导入旧的 `config.json\u002Fjsonl\u002Fprice_history`\n- `spider_v2.py` 默认从 SQLite 读取任务；只有显式传入 `--config \u003Cpath>` 时才会走 JSON 配置兼容模式\n- 默认数据库路径为 `data\u002Fapp.sqlite3`\n- Vite 开发服务器会将 `\u002Fapi`、`\u002Fauth`、`\u002Fws` 代理到 `http:\u002F\u002F127.0.0.1:8000`。\n- `npm run build` 先生成 `web-ui\u002Fdist\u002F`，`start.sh` 再复制到仓库根目录 `dist\u002F`。\n- FastAPI 负责提供根目录 `dist\u002Findex.html` 和 `dist\u002Fassets\u002F`。\n- `.\u002Fstart.sh` 默认输出访问地址 `http:\u002F\u002Flocalhost:8000` 和 API 文档 `http:\u002F\u002Flocalhost:8000\u002Fdocs`。\n\n### 测试与校验\n\n```bash\nPYTEST_DISABLE_PLUGIN_AUTOLOAD=1 pytest\ncd web-ui && npm run build\n```\n\n### 任务创建 API\n\n\u003Cdetails>\n\u003Csummary>点击展开 API 行为说明\u003C\u002Fsummary>\n\n- `POST \u002Fapi\u002Ftasks\u002Fgenerate`\n  - `decision_mode=ai`：返回 `202` 和 `job`，需要继续轮询进度。\n  - `decision_mode=keyword`：直接返回已创建任务。\n- `GET \u002Fapi\u002Ftasks\u002Fgenerate-jobs\u002F{job_id}`：查询 AI 任务生成进度。\n- `POST \u002Fauth\u002Fstatus`：校验 Web UI 登录凭据。\n\n\u003C\u002Fdetails>\n\n## 配置说明\n\n\u003Cdetails>\n\u003Csummary>点击展开常用配置项\u003C\u002Fsummary>\n\n### AI 与运行时\n\n- `OPENAI_API_KEY` \u002F `OPENAI_BASE_URL` \u002F `OPENAI_MODEL_NAME`：AI 模型接入必填项。\n- `PROXY_URL`：为 AI 请求单独指定 HTTP\u002FSOCKS5 代理。\n- `RUN_HEADLESS`：是否以无头模式运行爬虫；Docker 中应保持 `true`。\n- `SERVER_PORT`：后端监听端口，默认 `8000`。\n- `LOGIN_IS_EDGE`：本地环境可切换为 Edge 内核；Docker 镜像未内置 Edge，容器内会固定使用 Chromium。\n- `PCURL_TO_MOBILE`：是否将 PC 商品链接转换为移动端链接。\n\n### 通知\n\n- `NTFY_TOPIC_URL`\n- `GOTIFY_URL` \u002F `GOTIFY_TOKEN`\n- `BARK_URL`\n- `WX_BOT_URL`\n- `TELEGRAM_BOT_TOKEN` \u002F `TELEGRAM_CHAT_ID` \u002F `TELEGRAM_API_BASE_URL`\n- `WEBHOOK_*`\n\n### 代理轮换与失败保护\n\n- `PROXY_ROTATION_ENABLED`\n- `PROXY_ROTATION_MODE`\n- `PROXY_POOL`\n- `PROXY_ROTATION_RETRY_LIMIT`\n- `PROXY_BLACKLIST_TTL`\n- `TASK_FAILURE_THRESHOLD`\n- `TASK_FAILURE_PAUSE_SECONDS`\n- `TASK_FAILURE_GUARD_PATH`\n\n完整示例见 `.env.example`。\n\n\u003C\u002Fdetails>\n\n## Web 界面认证\n\n\u003Cdetails>\n\u003Csummary>点击展开认证说明\u003C\u002Fsummary>\n\n- Web UI 当前使用登录页收集账号密码，并通过 `POST \u002Fauth\u002Fstatus` 校验。\n- 登录成功后，前端会在浏览器本地保存登录状态，用于路由守卫和 WebSocket 初始化。\n- 默认账号密码为 `admin\u002Fadmin123`，生产环境请务必修改。\n\n\u003C\u002Fdetails>\n\n## 🚀 工作流程\n\n下图描述了单个监控任务从启动到完成的核心处理逻辑。主服务运行于 `src.app`，按用户操作或定时调度启动一个或多个任务进程。\n\n```mermaid\ngraph TD\n    A[启动监控任务] --> B[选择账号\u002F代理配置];\n    B --> C[任务: 搜索商品];\n    C --> D{发现新商品?};\n    D -- 是 --> E[抓取商品详情 & 卖家信息];\n    E --> F[下载商品图片];\n    F --> G[调用AI进行分析];\n    G --> H{AI是否推荐?};\n    H -- 是 --> I[发送通知];\n    H -- 否 --> J[保存记录到 SQLite];\n    I --> J;\n    D -- 否 --> K[翻页\u002F等待];\n    K --> C;\n    J --> C;\n    C --> L{触发风控\u002F异常?};\n    L -- 是 --> M[账号\u002F代理轮换并重试];\n    M --> C;\n```\n\n## 常见问题\n\n\u003Cdetails>\n\u003Csummary>点击展开常见问题\u003C\u002Fsummary>\n\n### AI 任务创建为什么不是立即完成？\n\nAI 模式会先生成分析标准，再创建任务。现在该流程已改为后台 job，提交后会显示独立进度弹窗，避免表单长时间卡住。\n\n### 区域筛选为什么默认建议留空？\n\n区域筛选会显著减少搜索结果，适合明确只看某个区域的场景。若你先验证整体市场，建议先不填。\n\n### 本地页面打开后提示前端构建产物不存在？\n\n说明根目录 `dist\u002F` 缺失。可直接执行 `.\u002Fstart.sh`，或先在 `web-ui\u002F` 里执行 `npm run build`，再确认构建产物已复制到仓库根目录。\n\n### `.\u002Fstart.sh` 为什么提示缺少 Playwright 或浏览器？\n\n这是脚本的前置检查。请先安装 Playwright CLI 与 Chromium，并确保系统中可用 Chrome \u002F Edge（Linux 环境也可用 Chromium），然后重新执行 `.\u002Fstart.sh`。\n\n\u003C\u002Fdetails>\n\n\n\n## 致谢\n\n\u003Cdetails>\n\u003Csummary>点击展开致谢内容\u003C\u002Fsummary>\n\n本项目在开发过程中参考了以下优秀项目，特此感谢：\n\n- [superboyyy\u002Fxianyu_spider](https:\u002F\u002Fgithub.com\u002Fsuperboyyy\u002Fxianyu_spider)\n\n以及感谢LinuxDo相关人员的脚本贡献\n\n- [@jooooody](https:\u002F\u002Flinux.do\u002Fu\u002Fjooooody\u002Fsummary)\n\n以及感谢 [LinuxDo](https:\u002F\u002Flinux.do\u002F) 社区。\n\n以及感谢 ClaudeCode\u002FGemini\u002FCodex 等模型工具，解放双手 体验Vibe Coding的快乐。\n\n\u003C\u002Fdetails>\n\n\n## 注意事项\n\n\u003Cdetails>\n\u003Csummary>点击展开注意事项详情\u003C\u002Fsummary>\n\n- 请遵守闲鱼的用户协议和robots.txt规则，不要进行过于频繁的请求，以免对服务器造成负担或导致账号被限制。\n- 本项目仅供学习和技术研究使用，请勿用于非法用途。\n- 本项目采用 [MIT 许可证](LICENSE) 发布，按\"现状\"提供，不提供任何形式的担保。\n- 项目作者及贡献者不对因使用本软件而导致的任何直接、间接、附带或特殊的损害或损失承担责任。\n- 如需了解更多详细信息，请查看 [免责声明](DISCLAIMER.md) 文件。\n\n\u003C\u002Fdetails>\n\n## Star History\n\n[![Star History Chart](https:\u002F\u002Fapi.star-history.com\u002Fsvg?repos=Usagi-org\u002Fai-goofish-monitor&type=Date)](https:\u002F\u002Fwww.star-history.com\u002F#Usagi-org\u002Fai-goofish-monitor&Date)\n\n![Alt](https:\u002F\u002Frepobeats.axiom.co\u002Fapi\u002Fembed\u002Fb40d8a112271b4bddabadd8fe2635be3c1aa28a3.svg \"Repobeats analytics image\")\n","闲鱼智能监控系统是一个基于Playwright和AI技术实现的多任务实时\u002F定时监控与智能分析工具，旨在帮助用户从海量商品中高效找到心仪产品。其核心功能包括Web可视化管理界面、自然语言创建任务、多模态模型深度分析商品、多任务并发执行以及高级筛选条件设置等。该系统支持通过多种渠道进行即时通知，并具备定时调度能力，同时实现了账号与代理的轮换机制以提高稳定性。适用于需要频繁关注特定类型或价格区间内二手商品更新的个人用户及小型团队，特别适合那些希望利用自动化工具提升搜索效率并减少手动操作时间的人群。",2,"2026-06-11 03:39:34","high_star"]