douyudm
v2.1.1
Published
实时获取斗鱼弹幕
Downloads
525
Maintainers
Readme
douyudm
基于websocket实时获取斗鱼弹幕
>= 2.0.0 不再支持WEB引用
安装(命令行)
npm i -g douyudm
or
yarn global add douyudm
使用(命令行)
通过命令行监听,默认显示,--debug
开启输出到文件,默认保存当前运行目录
douyudm -i 房间号
更多命令查看 douyudm --help
安装(API)
npm i douyudm
or
yarn add douyudm
使用(API)
通过库调用自行封装
//引入类库
const douyu = require('douyudm')
//设置房间号,初始化
const roomId = 102965
const opts = {
debug: true, // 默认关闭 false
}
const room = new douyu(roomId, opts)
//系统事件
room.on('connect', function () {
console.log('[connect] roomId=%s', this.roomId)
})
room.on('disconnect', function () {
console.log('[disconnect] roomId=%s', this.roomId)
})
room.on('error', function(err) {
console.log('[error] roomId=%s', this.roomId)
})
//消息事件
room.on('chatmsg', function(res) {
console.log('[chatmsg]', `<lv ${res.level}> [${res.nn}] ${res.txt}`)
})
room.on('loginres', function(res) {
console.log('[loginres]', '登录成功')
})
room.on('uenter', function(res) {
console.log('[uenter]', `${res.nn}进入房间`)
})
//开始监听
room.run()
事件列表
| 系统事件 | 描述 | |:----------:|:--------:| | connect | 连接 | | disconnect | 断开 | | error | 错误监听 |
| 消息事件 | 描述 | |:---------------------:|:----------------------:| | loginres | 登入 | | pingreq | 跟随 loginres 一起 | | chatmsg | 弹幕消息 | | uenter | 进入房间 | | upgrade | 用户等级提升 | | rss | 房间开播提醒 | | bc_buy_deserve | 赠送酬勤通知 | | ssd | 超级弹幕 | | spbc | 房间内礼物广播 | | dgb | 赠送礼物 | | onlinegift | 领取在线鱼丸 | | ggbb | 房间用户抢红包 | | rankup | 房间内top10变化消息 | | ranklist | 广播排行榜消息 | | mrkl | 心跳 | | erquizisn | 鱼丸预言 | | blab | 粉丝等级升级 | | rri | 未知的消息事件 | | synexp | 未知的消息事件 | | noble_num_info | 未知的消息事件 | | gbroadcast | 未知的消息事件 | | qausrespond | 未知的消息事件 | | wiru | 未知的消息事件 | | wirt | 未知的消息事件 | | mcspeacsite | 未知的消息事件 | | rank_change | 未知的消息事件 | | srres | 未知的消息事件 | | anbc | 未知的消息事件 | | frank | 未知的消息事件 | | rnewbc | 未知的消息事件 | | nlkstatus | 未知的消息事件 | | pandoraboxinfo | 未知的消息事件 | | ro_game_succ | 未知的消息事件 | | lucky_wheel_star_pool | 未知的消息事件 | | tsgs | 未知的消息事件 | | fswrank | 未知的消息事件 | | tsboxb | 未知的消息事件 | | cthn | 未知的消息事件 | | configscreen | 估计是全屏广播显示礼物 | | rnewbc | 未知的消息事件 |
斗鱼STT序列化反序列化库
STT序列化规定如下:
- 键key和值value直接采用
@=
分割- 数组采用
/
分割- 如果key或者value中含有字符
/
, 则使用@S
转义- 如果key或者value中含有字符
@
, 则使用@A
转义
序列化测试
npm run test:stt
or
yarn test:stt
后话
坑太多了,github上的库大部分都是不能使用的,如果近期更新的可以判断使用的新接口,review了几乎所有相关的库,都是依据斗鱼自己官方平台的方法发起tcp连接?但根本连不上,一直拒绝...
看了下能使用的库,都是通过websocket建立的连接,立马修改,不出片刻撸完,发现发送数据的格式有点难搞,虽说示意图挺清楚的,但是用Buffer传输死活没有相应的消息,调试太磨人心性了,玛德,直接去把斗鱼网页上的方法扒下来。
通过webpack打包混淆代码乍一眼看去很混乱,其实仔细观察还是有规律寻找的。
文档中编码的几个固定参数均为数字,在webpack中数字的混淆我还没见过,按这个思路精准的找到这段代码。经过我十几分钟的理解,提取出 bufferCoder.js
斗鱼自有的序列化,反序列化方法可以查看 stt.js