公司内网不让装录屏软件,于是我用 ffmpeg 自己封装了一个 CLI 工具

2 小时 59 分钟前
 gdjdkid2014

公司内网不让装录屏软件,于是我用 ffmpeg 自己封装了一个 CLI 工具

起因很简单:公司内网管控比较严,录屏软件装不上,OBS 装不了,Win+G 又没有权限开,但 ffmpeg 不知道为什么没有被拦——它就静静地躺在某个服务器目录里,能用。

于是就想着,ffmpeg 本身支持录屏,能不能把那一长串命令参数封装一下,做成一个随时能跑的小工具,录完就走,不依赖任何需要安装权限的软件。

就这样写了这个东西,叫 ScreenRecorder-cli

项目地址:
https://github.com/gdjdkid/ScreenRecorder-cli


痛点在哪

ffmpeg 本身当然能录屏,但命令太难记了,每次临时录东西都要现查参数:

ffmpeg -f gdigrab -framerate 30 -i desktop \
  -f dshow -i audio="virtual-audio-capturer" \
  -f dshow -i audio="麦克风 (Conexant ISST Audio)" \
  -filter_complex "[1:a][2:a]amerge=inputs=2[a]" \
  -map 0:v -map "[a]" \
  -c:v libx264 -crf 23 -preset veryfast \
  -c:a aac -b:a 128k \
  recording_2025-05-17_10-30-00.mp4

音频设备名拼错一个字符就报错,时间戳要手动写,输出路径每次都要重新指定。在工作中临时录个演示或者操作步骤,效率反而比直接截图还低。

所以我想做的事情就一件:把这些参数固化下来,音频设备名保存一次,之后一条命令搞定。


目前实现了什么


基本用法

# 安装
npm install -g screenrecorder-cli

# 第一次用,先查一下有哪些音频设备
screenrec devices

# 把设备名保存到配置,之后不用再输
screenrec set-device --mic "麦克风 (Conexant ISST Audio)" --system "virtual-audio-capturer"

# 开始录制,Ctrl+C 停止,文件自动保存
screenrec start

# 临时指定输出路径和帧率
screenrec start -o D:\Videos -r 60

# 不录音频
screenrec start --no-audio

# 查看当前配置
screenrec show-config

有几个地方没想清楚,想听听意见

1. Windows 系统音频需要额外装一个驱动
录系统声音需要装 screen-capture-recorder(开源的 DirectShow 驱动),不装只能录麦克风。在内网受限环境下这个驱动不一定能装,目前没找到绕过的方式,只是在文档里说明了。

2. Linux 部分是按文档写的,没有实机测过
我自己用 Windows ,Linux 下 x11grab + pulseaudio 的逻辑是照着 ffmpeg 文档写的,不同发行版差异可能不小。有 Linux 用户的话能帮忙验证一下吗。

3. 只能录全屏
目前没有窗口选择或区域选择。ffmpeg 的 gdigrab 支持 -i title=窗口标题,但窗口标题需要手动输入,不太实用。有没有更好的思路?

4. 输出格式写死了 mp4
编码用 libx264 ,没有其他格式的选项。有没有人有别的格式需求?


技术栈


最开始只是为了解决自己工作里的问题,后来整理了一下结构,加了跨平台支持,就顺手放出来了。如果有人在类似受限的内网环境下办公,或者单纯想要一个轻量的命令行录屏方案,可以试一下。

macOS 和 Linux 用户帮忙验证一下跨平台逻辑有没有问题就更好了,Issues 和 PR 都欢迎。

430 次点击
所在节点    分享创造
6 条回复
409164
2 小时 58 分钟前
这个很方便
gdjdkid2014
2 小时 57 分钟前
@409164 感谢老哥的肯定😃
noqwerty
2 小时 35 分钟前
感觉不如写个 shell alias 😂没必要再引入一个 node 依赖吧
gdjdkid2014
1 小时 40 分钟前
@noqwerty 没错,我确实在公司本地写了个 shell 脚本,然后 alias 直接在 git bash 用,很方便😆
boy666
1 小时 19 分钟前
不让装软件的本意就是不让录屏吧..
gdjdkid2014
1 小时 11 分钟前
@boy666 上有政策下有对策😅

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1213276

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX