问题背景
在Linux Docker环境中运行涉及中文显示的应用时(如Selenium网页截图、PDF生成等),经常会遇到中文显示为方块或乱码的问题。这是因为Linux系统默认没有安装中文字体所导致的。
解决方案
我们可以从Windows系统复制常用中文字体到Docker容器中来解决这个问题。以下是详细步骤:
1. 从Windows系统导出字体
            
            
              bash
              
              
            
          
          # Windows字体目录位置
C:\Windows\Fonts
# 1. 创建临时目录
mkdir D:\temp_fonts
# 2. 复制需要的中文字体到临时目录
# 建议复制以下常用中文字体:(省事就全部复制)
- SimSun.ttf (宋体)
- SimHei.ttf (黑体)
- Microsoft YaHei.ttf (微软雅黑)
- KaiTi.ttf (楷体)
- FangSong.ttf (仿宋)
        2. 压缩字体文件
            
            
              bash
              
              
            
          
          # 使用7-Zip将字体文件压缩为zip格式
# 右键选择临时字体目录 -> 7-Zip -> 添加到压缩文件
# 选择zip格式,创建 chinese_fonts.zip
        3. 传输到Linux服务器
            
            
              bash
              
              
            
          
          # 使用scp命令传输文件到Linux服务器
scp D:\temp_fonts\chinese_fonts.zip root@your_server_ip:/root/
# 或使用其他文件传输工具如FileZilla等
        4. 在Linux服务器上处理文件
            
            
              bash
              
              
            
          
          # 1. 登录服务器
ssh root@your_server_ip
# 2. 创建字体目录
mkdir -p /usr/share/fonts/chinese
# 3. 解压字体文件
cd /root/
unzip chinese_fonts.zip -d /usr/share/fonts/chinese/
# 4. 设置权限
chmod -R 755 /usr/share/fonts/chinese
        5. 复制到Docker容器
            
            
              bash
              
              
            
          
          # 1. 查看运行中的容器
docker ps
# 2. 复制字体到容器
docker cp /usr/share/fonts/chinese your_container_id:/usr/share/fonts/
# 3. 进入容器
docker exec -it your_container_id bash
# 4. 设置字体权限
chmod -R 755 /usr/share/fonts/chinese
# 5. 更新字体缓存
fc-cache -fv
# 6. 验证字体安装
fc-list :lang=zh
        验证安装
            
            
              python
              
              
            
          
          # Python代码示例:测试中文字体
from PIL import Image, ImageDraw, ImageFont
def test_font():
    # 创建图片
    img = Image.new('RGB', (400, 100), color='white')
    d = ImageDraw.Draw(img)
    
    # 使用中文字体
    font = ImageFont.truetype('/usr/share/fonts/chinese/SimSun.ttf', 24)
    
    # 绘制中文文本
    d.text((10,10), "测试中文字体显示", font=font, fill='black')
    
    # 保存图片
    img.save('test.png')
test_font()
        常见问题解决
- 
字体文件权限问题
如果遇到权限问题,执行:
chmod 644 /usr/share/fonts/chinese/*
chmod 755 /usr/share/fonts/chinese - 
字体缓存更新失败
 
            
            
              bash
              
              
            
          
          # 清理字体缓存后重新生成
rm -rf /var/cache/fontconfig/*
fc-cache -fv
        - 容器重启后字体消失
 
            
            
              bash
              
              
            
          
          # 将字体目录挂载到容器
docker run -v /usr/share/fonts/chinese:/usr/share/fonts/chinese ...
        相关命令参考
            
            
              bash
              
              
            
          
          # 查看所有中文字体
fc-list :lang=zh
# 查看字体详细信息
fc-match -v "字体名称"
# 检查字体配置
fc-conflist
# 清理字体缓存
fc-cache -fv