@liaopen123/xesopencli
v0.8.0
Published
xesopencli — fork with xesv5 workorder CLIs; website as CLI (Playwright MCP).
Maintainers
Readme
OpenCLI
本 fork 发布说明:npm 包名为
@liaopen123/xesopencli,命令为xesopencli(与上游opencli并存不冲突)。
安装:npm install -g @liaopen123/xesopencli· 源码:https://github.com/liaopen123/opencli
把任何网站变成你的命令行工具。
零风控 · 复用 Chrome 登录 · AI 自动发现接口 · 80+ 命令 · 19 站点
OpenCLI 将任何网站变成命令行工具 — B站、知乎、小红书、Twitter/X、Reddit、YouTube 等 19 个站点 — 复用浏览器登录态,AI 驱动探索。
目录
亮点
- 多站点覆盖 — B站、知乎、小红书、Twitter、Reddit 等 19 个站点,80+ 命令
- 零风控 — 复用 Chrome 登录态,无需存储任何凭证
- 自修复配置 —
opencli setup自动发现 Token;opencli doctor诊断 10+ 工具配置;--fix一键修复 - AI 原生 —
explore自动发现 API,synthesize生成适配器,cascade探测认证策略 - 动态加载引擎 — 声明式的
.yaml或者底层定制的.ts适配器,放入clis/文件夹即可自动注册生效
前置要求
- Node.js: >= 18.0.0
- Chrome 浏览器正在运行,且已登录目标网站(如 bilibili.com、zhihu.com、xiaohongshu.com)
⚠️ 重要:大多数命令复用你的 Chrome 登录状态。运行命令前,你必须已在 Chrome 中打开目标网站并完成登录。如果获取到空数据或报错,请先检查你的浏览器登录状态。
OpenCLI 通过 Playwright MCP Bridge 扩展与你的浏览器通信。
Playwright MCP Bridge 扩展配置
- 安装 Playwright MCP Bridge 扩展
- 运行
opencli setup— 自动发现 Token、分发到各工具、验证连通性:
opencli setup交互式 TUI 会:
- 🔍 从 Chrome 自动发现
PLAYWRIGHT_MCP_EXTENSION_TOKEN(无需手动复制) - ☑️ 显示所有支持的工具(Codex、Cursor、Claude Code、Gemini CLI 等)
- ✏️ 只更新你选中的文件(空格切换,回车确认)
- 🔌 完成后自动验证浏览器连通性
Tip:后续诊断和维护用
opencli doctor:opencli doctor # 只读 Token 与配置诊断 opencli doctor --live # 额外测试浏览器连通性 opencli doctor --fix # 修复不一致的配置(交互确认) opencli doctor --fix -y # 无交互直接修复所有配置
配置你的 MCP 客户端(如 Claude/Cursor 等):
{
"mcpServers": {
"playwright": {
"command": "npx",
"args": ["-y", "@playwright/mcp@latest", "--extension"],
"env": {
"PLAYWRIGHT_MCP_EXTENSION_TOKEN": "<你的-token>"
}
}
}
}在终端环境变量中导出(建议写进 ~/.zshrc):
export PLAYWRIGHT_MCP_EXTENSION_TOKEN="<你的-token>"快速开始
npm 全局安装(推荐)
npm install -g @jackwener/opencli
opencli setup # 首次使用:配置 Playwright MCP token直接使用:
opencli list # 查看所有命令
opencli list -f yaml # 以 YAML 列出所有命令
opencli hackernews top --limit 5 # 公共 API,无需浏览器
opencli bilibili hot --limit 5 # 浏览器命令
opencli zhihu hot -f json # JSON 输出
opencli zhihu hot -f yaml # YAML 输出从源码安装(面向开发者)
git clone [email protected]:jackwener/opencli.git
cd opencli
npm install
npm run build
npm link # 链接到全局环境
opencli list # 可以在任何地方使用了!更新
npm install -g @jackwener/opencli@latest内置命令
19 个站点 · 80+ 命令 — 运行 opencli list 查看完整注册表。
| 站点 | 命令 | 数量 | 模式 |
|------|------|:----:|------|
| twitter | trending bookmarks profile search timeline thread following followers notifications post reply delete like article follow unfollow bookmark unbookmark | 18 | 🔐 浏览器 |
| reddit | hot frontpage popular search subreddit read user user-posts user-comments upvote save comment subscribe saved upvoted | 15 | 🔐 浏览器 |
| bilibili | hot search me favorite history feed subtitle dynamic ranking following user-videos | 11 | 🔐 浏览器 |
| v2ex | hot latest topic daily me notifications | 6 | 🌐 / 🔐 |
| xueqiu | feed hot-stock hot search stock watchlist | 6 | 🔐 浏览器 |
| xiaohongshu | search notifications feed me user | 5 | 🔐 浏览器 |
| youtube | search video transcript | 3 | 🔐 浏览器 |
| zhihu | hot search question | 3 | 🔐 浏览器 |
| boss | search detail | 2 | 🔐 浏览器 |
| coupang | search add-to-cart | 2 | 🔐 浏览器 |
| bbc | news | 1 | 🌐 公共 API |
| ctrip | search | 1 | 🔐 浏览器 |
| github | search | 1 | 🌐 公共 API |
| hackernews | top | 1 | 🌐 公共 API |
| linkedin | search | 1 | 🔐 浏览器 |
| reuters | search | 1 | 🔐 浏览器 |
| smzdm | search | 1 | 🔐 浏览器 |
| weibo | hot | 1 | 🔐 浏览器 |
| yahoo-finance | quote | 1 | 🔐 浏览器 |
输出格式
所有内置命令都支持 --format / -f,可选值为 table、json、yaml、md、csv。
list 命令也支持同样的格式参数,同时继续兼容 --json。
opencli list -f yaml # 用 YAML 列出命令注册表
opencli bilibili hot -f table # 默认:富文本表格
opencli bilibili hot -f json # JSON(适合传给 jq 或者各类 AI Agent)
opencli bilibili hot -f yaml # YAML(更适合人类直接阅读)
opencli bilibili hot -f md # Markdown
opencli bilibili hot -f csv # CSV
opencli bilibili hot -v # 详细模式:展示管线执行步骤调试信息致 AI Agent(开发者指南)
如果你是一个被要求查阅代码并编写新 opencli 适配器的 AI,请遵守以下工作流。
快速模式:只想为某个页面快速生成一个命令?看 CLI-ONESHOT.md — 给一个 URL + 一句话描述,4 步搞定。
完整模式:在编写任何新代码前,先阅读 CLI-EXPLORER.md。它包含完整的适配器探索开发指南、API 探测流程、5级认证策略以及常见陷阱。
# 1. Deep Explore — 网络拦截 → 响应分析 → 能力推理 → 框架检测
opencli explore https://example.com --site mysite
# 2. Synthesize — 从探索成果物生成 evaluate-based YAML 适配器
opencli synthesize mysite
# 3. Generate — 一键完成:探索 → 合成 → 注册
opencli generate https://example.com --goal "hot"
# 4. Strategy Cascade — 自动降级探测:PUBLIC → COOKIE → HEADER
opencli cascade https://api.example.com/data探索结果输出到 .opencli/explore/<site>/。
常见问题排查
- "Failed to connect to Playwright MCP Bridge" 报错
- 确保你当前的 Chrome 已安装且开启了 Playwright MCP Bridge 浏览器插件。
- 如果是刚装完插件,需要重启 Chrome 浏览器。
- 返回空数据,或者报错 "Unauthorized"
- Chrome 里的登录态可能已经过期(甚至被要求过滑动验证码)。请打开当前 Chrome 页面,在新标签页重新手工登录或刷新该页面。
- Node API 错误 (如 parseArgs, fs 等)
- 确保 Node.js 版本
>= 18。旧版不支持我们使用的现代核心库 API。
- 确保 Node.js 版本
- Token 问题
- 运行
opencli doctor诊断所有工具的 Token 配置状态。 - 使用
opencli doctor --live测试浏览器连通性。
- 运行
版本发布
npm version patch # 0.1.0 → 0.1.1
npm version minor # 0.1.0 → 0.2.0
# 推送 tag,GitHub Actions 将自动执行发版和 npm 发布
git push --follow-tags