Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/flxxyz/douyudm

基于websocket实时获取斗鱼弹幕 (鸽了doge
https://github.com/flxxyz/douyudm

danmaku danmu douyu douyu-stt

Last synced: 4 days ago
JSON representation

基于websocket实时获取斗鱼弹幕 (鸽了doge

Awesome Lists containing this project

README

        

# douyudm

基于websocket实时获取斗鱼弹幕

Downloads
Version
License

> \>= 2.0.0 不再支持**WEB**引用

## 安装(命令行)

```shell
npm i -g douyudm
or
yarn global add douyudm
```

## 使用(命令行)

通过命令行监听,默认显示,`--debug`开启输出到文件,默认保存当前运行目录

```shell
douyudm -i 房间号
```

更多命令查看 `douyudm --help`

## 安装(API)

```shell
npm i douyudm
or
yarn add douyudm
```

## 使用(API)

通过库调用自行封装

```javascript
//引入类库
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]', ` [${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序列化规定如下:

> 1. 键key和值value直接采用`@=`分割
> 2. 数组采用`/`分割
> 3. 如果key或者value中含有字符`/`, 则使用`@S`转义
> 4. 如果key或者value中含有字符`@`, 则使用`@A`转义

### 序列化测试

```javascript
npm run test:stt
or
yarn test:stt
```

## 后话

坑太多了,github上的库大部分都是不能使用的,如果近期更新的可以判断使用的新接口,review了几乎所有相关的库,都是依据斗鱼自己官方平台的方法发起tcp连接?但根本连不上,一直拒绝...

看了下能使用的库,都是通过websocket建立的连接,立马修改,不出片刻撸完,发现发送数据的格式有点难搞,虽说示意图挺清楚的,但是用Buffer传输死活没有相应的消息,调试太磨人心性了,玛德,直接去把斗鱼网页上的方法扒下来。

通过webpack打包混淆代码乍一眼看去很混乱,其实仔细观察还是有规律寻找的。

文档中编码的几个固定参数均为数字,在webpack中数字的混淆我还没见过,按这个思路精准的找到这段代码。经过我十几分钟的理解,提取出 [**bufferCoder.js**](test/old/bufferCoder.js)

斗鱼自有的序列化,反序列化方法可以查看 [**stt.js**](src/stt.js)