dompdf 默认不支持中文,需手动配置支持 unicode 的中文字体(如 notosanscjk)、启用字体目录、设置默认字体并确保 html 编码统一为 utf-8,才能正常渲染中文文本。
dompdf 默认不支持中文,需手动配置支持 unicode 的中文字体(如 notosanscjk)、启用字体目录、设置默认字体并确保 html 编码统一为 utf-8,才能正常渲染中文文本。
在使用 Dompdf(v0.8.0+)将含中文的 HTML 转换为 PDF 时,出现“方块乱码”( 或 □)是典型字体缺失问题。Dompdf 内置字体(如 DejaVu Sans)虽支持部分 Unicode 字符,但不包含中日韩(CJK)汉字字形,因此即使 HTML 正确声明 UTF-8 编码且浏览器可正常显示,PDF 渲染仍会失败。
准备支持 CJK 的 TrueType 字体文件
推荐使用 Google 开源字体 Noto Sans CJK(如 NotoSansCJKtc-Regular.ttf,繁体中文版),下载后存放于项目字体目录(例如 assets/fonts/)。注意:字体文件名需与 CSS 或配置中引用的名称严格一致(区分大小写、不含空格)。
显式配置字体路径与默认字体
必须通过 $options->set('fontDir', ...) 指向字体目录,并设置 defaultFont 为该字体的注册名(非文件名)。Dompdf 会在首次运行时自动解析 .ttf 并生成缓存字体文件(.ufm, .php),因此首次渲染可能稍慢,且需确保 fontDir 目录可写。
禁用冗余的 HTML 字体声明(关键!)
<style>@font-face{...}</style> 在 Dompdf 中基本无效(v0.8.0 不支持动态 @font-face 加载远程或相对路径字体)。应完全移除此类 CSS,仅依赖 PHP 层配置的 defaultFont。
确保全流程 UTF-8 编码一致
require 'assets/dompdf1/autoload.inc.php';// ⚠️ 关键:指定字体目录(绝对路径,确保可读写)define('DOMPDF_FONT_DIR', __DIR__ . '/assets/fonts/');$options = new Options();$options->set('isPhpEnabled', false); // 生产环境建议关闭 PHP 解析(安全)$options->set('fontDir', DOMPDF_FONT_DIR);$options->set('defaultFont', 'NotoSansCJKtc-Regular'); // 注意:此处为字体注册名,非文件名$dompdf = new Dompdf($options);$html = $this->load->view('view_view', $data, TRUE);// 无需 mb_convert_encoding,只要 $html 本身是 UTF-8 即可$dompdf->loadHtml($html, 'UTF-8'); // 显式声明编码更稳妥$dompdf->setPaper('A4', 'landscape');$dompdf->render();$dompdf->stream('View.pdf', ['Attachment' => false]);exit;
完成上述配置后,中文将清晰渲染,无方块、无乱码。Dompdf 的中文字体支持本质是「预加载 + 缓存映射」,而非实时解析,因此一次配置,长期生效。