功能特性
- 🔍 多源聚合搜索:内置数十个免费资源站点,一次搜索立刻返回全源结果
- 📄 丰富详情页:支持剧集列表、演员、年份、简介等完整信息展示
- ▶️ 流畅在线播放:集成 HLS.js & ArtPlayer
- ❤️ 收藏 + 继续观看:支持 Redis/D1 存储,多端同步进度
- 📱 PWA:离线缓存、安装到桌面/主屏,移动端原生体验
- 🌗 响应式布局:桌面侧边栏 + 移动底部导航,自适应各种屏幕尺寸
- 🚀 极简部署:一条 Docker 命令即可将完整服务跑起来,或免费部署到 Vercel 和 Cloudflare
- 👿 智能去广告:自动跳过视频中的切片广告(实验性)
部署
该项目支持 Vercel、Docker 和 Cloudflare 部署
项目地址https://github.com/senshinya/MoonTV
演示如下



Vercel 部署
推荐使用,零运维成本,免费额度足够个人使用
- Fork 本仓库到你的 GitHub 账户
- 登陆 Vercel,点击 Add New → Project,选择 Fork 后的仓库
- (强烈建议)设置 PASSWORD 环境变量
- 保持默认设置完成首次部署
- 如需自定义 config.json,请直接修改 Fork 后仓库中该文件
- 每次 Push 到 main 分支将自动触发重新构建
部署完成后即可通过分配的域名访问,也可以绑定自定义域名
Cloudflare 部署
普通部署(localstorage)
- Fork 本仓库到你的 GitHub 账户
- 登陆 Cloudflare,点击 计算(Workers)-> Workers 和 Pages,点击创建
- 选择 Pages,导入现有的 Git 存储库,选择 Fork 后的仓库
- 构建命令填写 pnpm install –frozen-lockfile && pnpm run pages:build,预设框架为无,构建输出目录为 .vercel/output/static
- 保持默认设置完成首次部署。进入设置,将兼容性标志设置为 nodejs_compat
- (强烈建议)首次部署完成后进入设置,新增 PASSWORD 密钥(变量和机密下),而后重试部署
- 如需自定义 config.json,请直接修改 Fork 后仓库中该文件
- 每次 Push 到 main 分支将自动触发重新构建
D1 支持
- 点击 存储和数据库 -> D1 SQL 数据库,创建一个新的数据库,名称随意
- 进入刚创建的数据库,点击左上角的 Explore Data,将D1 初始化 中的内容粘贴到 Query 窗口后点击 Run All,等待运行完成
- 返回你的 pages 项目,进入 设置 -> 绑定,添加绑定 D1 数据库,选择你刚创建的数据库,变量名称填 DB
- 设置环境变量 NEXT_PUBLIC_STORAGE_TYPE,值为 d1;设置 USERNAME 和 PASSWORD 作为站长账号
- 重试部署
Docker 部署
适用于自建服务器 / NAS / 群晖等场景
- 直接运行(最简单)
# 拉取预构建镜像
docker pull ghcr.io/senshinya/moontv:latest
# 运行容器
# -d: 后台运行 -p: 映射端口 3000 -> 3000
docker run -d --name moontv -p 3000:3000 ghcr.io/senshinya/moontv:latest
访问 http://服务器 IP:3000 即可。(需自行到服务器控制台放通 3000 端口)
建议在 fork 的仓库中启用本仓库自带的 GitHub Actions 自动同步功能(见 .github/workflows/sync.yml)
如需手动同步主仓库更新,也可以使用 GitHub 官方的 Sync fork 功能
总结
MoonTV 是受 LibreTV 的启发而诞生的,所以两者用的配置文件的播放源 API 是通用的,懂得都懂这里就不展开了。个人觉得还是非常推荐部署的,如果不太刻意追求画质,其实这个 1080P 也完全够用了,没有广告,播放的速度很快,也不占用 NAS 端的上传带宽
© 版权声明
THE END
暂无评论内容