MoonTV 是一个开箱即用的、跨平台的影视聚合播放器。它基于 Next.js 14 + Tailwind CSS + TypeScript 构建,支持多资源搜索、在线播放、收藏同步、播放记录、本地/云端存储,让你可以随时随地畅享海量免费影视内容。
功能特性
多源聚合搜索:内置数十个免费资源站点,一次搜索立刻返回全源结果。
丰富详情页:支持剧集列表、演员、年份、简介等完整信息展示。
流畅在线播放:集成 HLS.js & VidStack。
收藏 + 继续观看:LocalStorage 存储,后续扩展 DB 存储。
PWA:离线缓存、安装到桌面/主屏,移动端原生体验。
响应式布局:桌面侧边栏 + 移动底部导航,自适应各种屏幕尺寸。
极简部署:一条 Docker 命令即可将完整服务跑起来,或免费部署到 Vercel。
智能去广告:自动跳过视频中的切片广告(实验性)
本项目支持 Vercel 和 Docker 部署,注意不支持 Cloudflare,后续亦无支持计划。
Vercel 部署
推荐使用,零运维成本,免费额度足够个人使用。
Fork 本仓库到你的 GitHub 账户。
登陆 Vercel,点击 Add New → Project,选择 Fork 后的仓库。
(强烈建议)设置 PASSWORD 环境变量。
保持默认设置完成首次部署。
如需自定义 config.json,请直接修改 Fork 后仓库中该文件。
每次 Push 到 main 分支将自动触发重新构建。
部署完成后即可通过分配的域名访问,也可以绑定自定义域名。
Docker 部署
适用于自建服务器 / NAS / 群晖等场景。
1. 直接运行(最简单)
# 拉取预构建镜像 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 即可。
2. docker-compose 示例
version: '3.9'
services:
moontv:
image: ghcr.io/senshinya/moontv:latest
container_name: moontv
restart: unless-stopped
ports:
- 3000:3000
environment:
- PASSWORD=12345
# 如需自定义配置,可挂载文件
# volumes:
# - ./config.json:/app/config.json:ro
执行:
docker compose up -d
随后同样访问 http://服务器 IP:3000
请勿使用 Pull Bot 自动同步
Pull Bot 会反复触发无效的 PR 和垃圾邮件,严重干扰项目维护。作者可能会直接拉黑所有 Pull Bot 自动发起的同步请求的仓库所有者。
推荐做法:
建议在 fork 的仓库中启用本仓库自带的 GitHub Actions 自动同步功能(见 .github/workflows/sync.yml)。
如需手动同步主仓库更新,也可以使用 GitHub 官方的 Sync fork 功能。
环境变量
安全与隐私提醒
强烈建议设置密码保护
为了您的安全和避免潜在的法律风险,我们强烈建议在部署时设置密码保护:
避免公开访问:不设置密码的实例任何人都可以访问,可能被恶意利用
防范版权风险:公开的视频搜索服务可能面临版权方的投诉举报
保护个人隐私:设置密码可以限制访问范围,保护您的使用记录
部署建议
设置环境变量 PASSWORD:为您的实例设置一个强密码
仅供个人使用:请勿将您的实例链接公开分享或传播
遵守当地法律:请确保您的使用行为符合当地法律法规
重要声明
本项目仅供学习和个人使用
请勿将部署的实例用于商业用途或公开服务
如因公开分享导致的任何法律问题,用户需自行承担责任
项目开发者不对用户的使用行为承担任何法律责任