Linux系统无头浏览器pupteer截图出来中文乱码

无头浏览器 Puppeteer 截图出现中文乱码(通常显示为方块或缺失字符),根本原因在于 Linux 服务器默认缺少中文字体库。Puppeteer 使用的 Chromium 浏览器无法渲染中文,是因为系统未安装支持中文的字体。


解决方案

根据公开资料,主流解决方式如下:

  • 安装中文字体到服务器
  • 更新字体缓存
  • (可选)在 Puppeteer 启动参数中指定中文字体

具体操作步骤(适用于 CentOS / Ubuntu / AliLinux 等)

  1. 安装 fontconfig(如未安装)

    bash 复制代码
    CentOS/RHEL
    yum install -y fontconfig
    
    Ubuntu/Debian
    apt-get update && apt-get install -y fontconfig
  2. 从 Windows 系统复制中文字体到服务器

    • 常用中文字体文件(位于 C:\Windows\Fonts\):

      • simsun.ttc(宋体)
      • msyh.ttc(微软雅黑)
      • simhei.ttf(黑体)
    • 将这些字体文件上传至服务器的 /usr/share/fonts/chinese/ 目录(若目录不存在则创建):

      bash 复制代码
      mkdir -p /usr/share/fonts/chinese
      通过 scp、rz 或其他方式上传字体文件至此目录
  3. 设置字体目录权限

    bash 复制代码
    chmod -R 755 /usr/share/fonts/chinese
  4. 刷新字体缓存

    bash 复制代码
    fc-cache -fv
  5. 验证中文字体是否安装成功

    bash 复制代码
    fc-list :lang=zh

    若输出包含 SimSunMicrosoft YaHei 等字体,则表示安装成功。

  6. (可选)在 Puppeteer 启动参数中指定字体

    在代码中添加 --font-family 参数,例如:

    js 复制代码
    const browser = await puppeteer.launch({
      headless: 'new',
      args: [
        '--no-sandbox',
        '--font-family=SimSun' // 指定默认中文字体
      ]
    });

Docker 部署场景

若使用 Docker 部署,可在 Dockerfile 中直接复制字体并安装:

dockerfile 复制代码
FROM node:18-alpine

安装 Chromium 依赖和中文字体
RUN apk add --no-cache \
    chromium \
    nss \
    freetype \
    ttf-liberation \
    wqy-zenhei \
    font-noto-cjk \
    fontconfig

复制中文字体(假设已将 msyh.ttc 放在本地目录)
COPY msyh.ttc /usr/share/fonts/

更新字体缓存
RUN fc-cache -fv

设置 Puppeteer 使用系统 Chromium
ENV PUPPETEER_SKIP_CHROMIUM_DOWNLOAD=true \
    PUPPETEER_EXECUTABLE_PATH=/usr/bin/chromium-browser

... 其他配置
总结

- 根本原因:Linux 服务器无中文字体。
- 核心解决:安装中文字体 + 运行 `fc-cache -fv`。
- 推荐字体:`SimSun`、`Microsoft YaHei`、`WenQuanYi Zen Hei`。
- 验证命令:`fc-list :lang=zh`。

完成上述操作后,Puppeteer 截图中文乱码问题即可解决。
相关推荐
LSL666_17 分钟前
4 Docker 镜像安装与容器启动
运维·docker·容器
坚持就完事了26 分钟前
Linux中的cp命令
linux·运维·服务器
切糕师学AI26 分钟前
使用 gdisk 快速判断硬盘分区表类型:是 GPT 还是 MBR?
linux·硬盘分区表·gdisk
2301_8009769328 分钟前
Linux的基本命令
linux·运维·服务器
原来是猿1 小时前
线程安全的单例模式
linux·服务器·开发语言·单例模式·策略模式
许愿OvO1 小时前
MySQL 8.3.0 运维与集群架构实战
运维·mysql·架构
凌云拓界1 小时前
青创赛终评手记:最后的成功
运维·科技·职场和发展·架构·创业创新
zjeweler1 小时前
宝藏网站推荐:云服务器特惠与网安学习资源的一站式聚合平台
运维·服务器·学习
尘世壹俗人1 小时前
如何检查服务器上消耗资源的程序是那个
服务器·前端·chrome
时空自由民.1 小时前
Linux,ESP IDF,NuttX OS使用的项目编译管理构建体系Kconfig + Kbuild(或基于 Make/CMake 的构建系统)
linux·运维·服务器