说明:之前有同学要求博主出个DPlayer
弹幕后端搭建教程,刚好本博客的Handsome
主题更新并完美适配了Dplayer
,然后就研究了下,发现了点小问题,如作者提供的弹幕API
加载不出弹幕,而且Typecho
当中的Dplayer
插件有点旧无法对接V3
后端,不知道其它程序插件是不是这样,这里博主只能使用HTML
代码直接输出调用,经测试已完全正常加载弹幕和观看。这里就说下搭建及使用方法。
【2020.10.3】
弹幕api接口已修复,长期可用,https://dplayer.moerats.com,如出现问题留言即可。
【2020.10.27】
由于有些人不太喜欢Docker搭建,所以下面补齐CentOS、Debian、Ubuntu手动搭建教程。
简介
DPlayer
是一个支持弹幕的HTML5
视频播放器。支持Bilibili
视频和danmaku
,支持HLS
、FLV
、MPEG DASH
、WebTorrent
以及其他视频格式,支持截屏、热键、切换清晰度以及字幕等。
安装
作者提供的弹幕后端搭建方法挺多的,这里选择一个搭建最快,版本最新的一种。
Github地址:https://github.com/MoePlayer/DPlayer-node
Docker安装
1、安装Docker
#CentOS 6
rpm -iUvh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
yum update -y
yum -y install docker-io
service docker start
chkconfig docker on
#CentOS 7、Debian、Ubuntu
curl -sSL https://get.docker.com/ | sh
systemctl start docker
systemctl enable docker
2、安装Docker Compose
curl -L https://github.com/docker/compose/releases/download/1.17.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
3、运行镜像
安装git
:
#Debian、Ubuntu系统
apt install git -y
#CentOS系统
yum install -y git
再使用命令:
#拉取源码
git clone https://github.com/MoePlayer/DPlayer-node.git
cd DPlayer-node
#新建镜像
docker-compose build
#拉取其它镜像并后台运行
docker-compose up -d
此时api
地址为http://ip:1207
,数据和日志存放在/root/dplayer
文件夹。
当然如果你想其它端口,或者修改存放文件夹路径,那你在上面的新建镜像之前,作出如下操作:
#编辑DPlayer-node文件夹的docker-compose.yml文件,部分修改如下
mongo:
volumes:
- ~/dplayer/db:/data/db #数据库存放文件夹,~/dplayer/db为映射在外部的路径,自行修改,
web:
ports:
- 1207:1207 #api映射到外部的端口,将前面的1207修改成你想要的即可
volumes:
- ~/dplayer/logs:/usr/src/app/logs #同数据库操作
- ~/dplayer/pm2logs:/root/.pm2/logs #同上
改完后再新建镜像即可,如果你已经新建镜像了,但想改,那就清空之前的镜像再修改,方法参考→传送门。
CentOS安装
提示:教程适用于CentOS 7、8系统。
1、安装NodeJS
curl -sL https://rpm.nodesource.com/setup_10.x | bash -
yum install nodejs git -y
2、安装Mongodb
#将下面命令一起复制进SSH客户端运行
cat <<EOF > /etc/yum.repos.d/mongodb.repo
[mongodb-org-4.0]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/7/mongodb-org/4.0/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-4.0.asc
EOF
#安装mongodb
yum -y install mongodb-org
systemctl start mongod
systemctl enable mongod
3、安装Redis
#CentOS 7系统
yum install epel-release -y
yum install redis -y
systemctl start redis
systemctl enable redis
#CentOS 8系统
yum install redis -y
systemctl start redis
systemctl enable redis
4、安装弹幕服务器
#拉取源码
git clone https://github.com/MoePlayer/DPlayer-node.git
cd DPlayer-node
npm i
npm i -g pm2
pm2 start index.js --name danmuapi
此时api
地址为http://ip:1207
。
Debian安装
提示:教程适用于Debian 8、9、10系统。
1、安装NodeJS
curl -sL https://deb.nodesource.com/setup_10.x | bash -
apt install -y git nodejs
2、安装Mongodb
#Debian 8系统
wget -qO - https://www.mongodb.org/static/pgp/server-4.0.asc | apt-key add -
echo "deb http://repo.mongodb.org/apt/debian jessie/mongodb-org/4.0 main" | tee /etc/apt/sources.list.d/mongodb-org-4.0.list
apt update -y
apt -y install mongodb-org
systemctl start mongod
systemctl enable mongod
#Debian 9系统
wget -qO - https://www.mongodb.org/static/pgp/server-4.0.asc | apt-key add -
echo "deb http://repo.mongodb.org/apt/debian stretch/mongodb-org/4.0 main" | tee /etc/apt/sources.list.d/mongodb-org-4.0.list
apt update -y
apt -y install mongodb-org
systemctl start mongod
systemctl enable mongod
#Debian 10系统
wget -qO - https://www.mongodb.org/static/pgp/server-4.2.asc | apt-key add -
echo "deb http://repo.mongodb.org/apt/debian buster/mongodb-org/4.2 main" | tee /etc/apt/sources.list.d/mongodb-org-4.2.list
apt update -y
apt -y install mongodb-org
systemctl start mongod
systemctl enable mongod
3、安装Redis
apt install redis-server -y
4、安装弹幕服务器
#拉取源码
git clone https://github.com/MoePlayer/DPlayer-node.git
cd DPlayer-node
npm i
npm i -g pm2
pm2 start index.js --name danmuapi
此时api
地址为http://ip:1207
。
Ubuntu安装
提示:教程适用于Ubuntu 16.04、18.04、20.04系统。
1、安装NodeJS
curl -sL https://deb.nodesource.com/setup_10.x | bash -
apt install -y git nodejs
2、安装Mongodb
#Ubuntu 16.04系统
wget -qO - https://www.mongodb.org/static/pgp/server-4.4.asc | sudo apt-key add -
echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu xenial/mongodb-org/4.4 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-4.4.list
apt update -y
apt install -y mongodb-org
systemctl start mongod
systemctl enable mongod
#Ubuntu 18.04系统
wget -qO - https://www.mongodb.org/static/pgp/server-4.4.asc | sudo apt-key add -
echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu bionic/mongodb-org/4.4 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-4.4.list
apt update -y
apt install -y mongodb-org
systemctl start mongod
systemctl enable mongod
#Ubuntu 20.04系统
wget -qO - https://www.mongodb.org/static/pgp/server-4.4.asc | sudo apt-key add -
echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu focal/mongodb-org/4.4 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-4.4.list
apt update -y
apt install -y mongodb-org
systemctl start mongod
systemctl enable mongod
3、安装Redis
apt install redis-server -y
4、安装弹幕服务器
#拉取源码
git clone https://github.com/MoePlayer/DPlayer-node.git
cd DPlayer-node
npm i
npm i -g pm2
pm2 start index.js --name danmuapi
此时api
地址为http://ip:1207
。
域名反代
如果你的博客已经开启了https
访问,那api
也需要https
地址,所以只使用ip:端口
是不行的,这里就需要使用域名反代了。博主喜欢Caddy
,所以这里说下宝塔和Caddy
反代,其它一键环境的建议看官方文档或自行搜索。
如果你服务器没有安装Nginx
/Apache
的,可以用下Caddy
,很方便很快,记得提前将域名解析到服务器。
1、宝塔反代
先进入宝塔面板,然后点击左侧网站,添加站点,然后再点击添加好了的域名名称,这时候就进入了站点配置,点击反向代理,目标URL
填入http://127.0.0.1:1207
,再启用反向代理即可。至于启用SSL
就不说了,直接在站点配置就可以看到。
2、Caddy反代
安装Caddy
:
wget -N --no-check-certificate https://raw.githubusercontent.com/iiiiiii1/doubi/master/caddy_install.sh && chmod +x caddy_install.sh && bash caddy_install.sh
#备用地址
wget -N --no-check-certificate https://www.moerats.com/usr/shell/Caddy/caddy_install.sh && chmod +x caddy_install.sh && bash caddy_install.sh
配置Caddy
:
#以下全部内容是一个整体,请修改域名后一起复制到SSH运行!
echo "xx.com {
tls admin@moerats.com
proxy / http://127.0.0.1:1207
}" > /usr/local/caddy/Caddyfile
tls
参数会自动帮你签发ssl
证书,如果你要使用自己的ssl
,改为tls /root/xx.crt /root/xx.key
即可。后面为ssl
证书路径。
启动Caddy
:
/etc/init.d/caddy start
反代好了后,你的API
地址就为https://xx.com
。
使用
作者提供了很多插件,这里列举一点:
Typecho:https://github.com/volio/DPlayer-for-typecho
Hexo:https://github.com/NextMoe/hexo-tag-dplayer
Z-Blog:https://github.com/fghrsh/DPlayer_for_Z-BlogPHP
Discuz!:https://coding.net/u/Click_04/p/video/git
WordPress:https://github.com/BlueCocoa/DPlayer-WordPress
不过Typecho
插件暂时用不了,其它程序暂时不清楚,所以这里提供一个播放器的HTML
代码,代码如下:
<link href="https://www.moerats.com/usr/dplayer/DPlayer.min.css" rel="stylesheet">
<div id="dplayer"></div>
<script src="https://www.moerats.com/usr/dplayer/DPlayer.min.js"></script>
<script src="https://cdnjs.loli.net/ajax/libs/blueimp-md5/2.10.0/js/md5.min.js"></script>
<script>
var url="https://www.moerats.com/xx.mp4"; //这里填写视频地址
var id=md5(url);
const dp = new DPlayer({
container: document.getElementById('dplayer'),
video: {
url: url
},
danmaku: {
id: id,
api: 'https://dplayer.moerats.com/' //这里填写弹幕地址
}
});
</script>
直接将代码贴进文章里即可,如果在Typecho
开发版中使用不正常的话,可能还需要用两排!!!
将代码上下围住使其强制输出,比如:
#特殊原因,不得已才加上o,使用的时候记得去掉
o!!!
代码
o!!!
还有更多功能及使用方法可以查看→传送门。
演示
博主知道有人懒搭建的,所以这里提供个弹幕API地址:https://dplayer.moerats.com/。
好了,可以在视频里发彩色弹幕了,如果该视频播放器不显示的话,刷新一下就行了。
大佬,请问弹幕id是怎么生成的,我根据你的教程搭建出来的接口,打开就报这个错误GET http://apidp.purvavideha.cn/?id=183f6653124c13ca6b924d021c233f52 502 (Bad Gateway)
以及这个错误:Access to XMLHttpRequest at 'http://apidp.purvavideha.cn/?id=183f6653124c13ca6b924d021c233f52' from origin 'null' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.
你用的插件?弹幕api设置和我文章给的一样就行,调用的v3,你给的连接都没v3
没有 也是html的页面,弹幕api是用的你的博客中的教程搭建的 在写的时候 需要在api连接中加上v3吗
这个不需要,后端自动帮你加,不过拉取b站弹幕的时候就需要手动加v3了,你可以f12看看哪里有问题。
老哥弹幕接口出了点问题.
欧克,已经修好了。
请教,安装都没问题,但打开播放器的时候加载弹幕失败,请问一般是什么问题,如何解决?
这个情况很多,你启动的时候使用docker-compose up,可以看链接日志
大佬请问下这是啥问题,前几天装好都好好的。
at parseError (/usr/src/app/node_modules/redis-parser/lib/parser.js:193:12) at parseType (/usr/src/app/node_modules/redis-parser/lib/parser.js:303:14)DPlayer-node 发生了一些意外:
ReplyError: NOAUTH Authentication required.
初步看了下,你先去DPlayer-node文件夹,使用docker-compose stop停掉容器,然后再使用docker-compose up -d启动容器,应该就好了。
应该是redis认证出了问题,我先看下。
我搭建了但是他不会保存弹幕啊。。。。
打开播放器的时候加载弹幕是失败还是?
成功了 哈哈哈 CTRL+F5 并且把<script src="/source/plugin/bingofans_video/template/dplayer/DPlayer.min.js" charset="UTF-8"></script>加了个charset="UTF-8"完美搞定
发了几百个弹幕,成功了几个。。。。好尴尬
大佬问问,因为服务器上本来有redis,所以我给他改了个IP 127.0.0.2:6379,连接也是成功的,docker里面显示启动成功。域名打开后和你的一样显示Not Found,放到HTML中,视频能正常打开,弹幕也能正常发送(进去提示加载弹幕,一秒左右消失,也没提示加载失败之类的,弹幕发送也没提示发送失败,而且正常在上面滚动,但是刷新视频后,弹幕消失,未保存到服务器),查看日志大部分显示{"message":"/v3/, user IP: 182.139.28.104","level":"info"}或者{"message":"/, user IP: 182.139.28.104","level":"info"},没有错误日志。我也尝试过卸载原来的redis,使用127.0.0.1:6379,但是依然那样,麻烦给指导指导大佬。具体效果可以看看https://www.bingoufan.com/1.html,呜呜呜
我的弹幕放在顶部或者底部 会偏移到画面外 是为何~~
这个貌似是播放器的问题,具体我也不清楚,好像在手机端竖频下会出现这情况。
我看了下 是我改播放器页面的时候 出了点问题 。
手机端微信百度浏览器之类 会把播放器替换 弹幕就不存在了
用谷歌浏览器吧。有的浏览器会变。
划水这个弹幕功能有脏话或者广告那些怎么管理。。。
那个东西会过滤吗。。我用官方的那个接口就不得行
这个问题还没考虑到,得研究下。
博主,发现你老喜欢用这个视频
是的,歌好听人也美,又没多的视频,所以一直就这个。
谢谢大佬
大佬问问,因为服务器上本来有redis,所以我给他改了个IP 127.0.0.2:6379,连接也是成功的,docker里面显示启动成功。域名打开后和你的一样显示Not Found,放到HTML中,视频能正常打开,弹幕也能正常发送(进去提示加载弹幕,一秒左右消失,也没提示加载失败之类的,弹幕发送也没提示发送失败,而且正常在上面滚动,但是刷新视频后,弹幕消失,未保存到服务器),查看日志大部分显示{"message":"/v3/, user IP: 182.139.28.104","level":"info"}或者{"message":"/, user IP: 182.139.28.104","level":"info"},没有错误日志。我也尝试过卸载原来的redis,使用127.0.0.1:6379,但是依然那样,麻烦给指导指导大佬。具体效果可以看看https://www.bingoufan.com/1.html