MoonTV 是一个开箱即用的、跨平台的影视聚合播放器。它基于 Next.js 14 + Tailwind CSS + TypeScript 构建,支持多资源搜索、在线播放、收藏同步、播放记录、本地/云端存储,让你可以随时随地畅享海量免费影视内容。

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

Docker 部署

适用于自建服务器 / NAS / 群晖等场景。

  1. 直接运行(最简单)
    拉取预构建镜像

    1
    docker pull ghcr.io/senshinya/moontv:latest
  2. 运行容器(注释:-d: 后台运行 -p: 映射端口 3000 -> 3000)

    1
    docker run -d --name moontv -p 3000:3000 ghcr.io/senshinya/moontv:latest
  3. 访问 http://服务器 IP:3000 即可。(需自行到服务器控制台放通 3000 端口)

Docker Compose 最佳实践

若你使用 docker compose 部署,以下是一些 compose 示例

local storage 版本

1
2
3
4
5
6
7
8
9
10
11
12
services:
moontv:
image: ghcr.io/senshinya/moontv:latest
container_name: moontv
restart: unless-stopped
ports:
- '3000:3000'
environment:
- PASSWORD=your_password
# 如需自定义配置,可挂载文件
# volumes:
# - ./config.json:/app/config.json:ro

Redis 版本(推荐,多账户数据隔离,跨设备同步)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
services:
moontv-core:
image: ghcr.io/senshinya/moontv:latest
container_name: moontv
restart: unless-stopped
ports:
- '3000:3000'
environment:
- USERNAME=admin
- PASSWORD=admin_password
- NEXT_PUBLIC_STORAGE_TYPE=redis
- REDIS_URL=redis://moontv-redis:6379
- NEXT_PUBLIC_ENABLE_REGISTER=true
networks:
- moontv-network
depends_on:
- moontv-redis
# 如需自定义配置,可挂载文件
# volumes:
# - ./config.json:/app/config.json:ro
moontv-redis:
image: redis
container_name: moontv-redis
restart: unless-stopped
networks:
- moontv-network
# 如需持久化
# volumes:
# - ./data:/data
networks:
moontv-network:
driver: bridge

另外有大佬做好了客户端,安卓可以到下面链接去大佬的仓库下载使用(帮大佬点赞)
https://github.com/zimplexing/OrionTV