PHP字体子集生成及“failed to decode downloaded font”错误修复
为了优化网页加载速度,常常需要创建字体子集,只包含网页实际用到的字符。然而,使用PHP生成字体子集时,可能会遇到“failed to decode downloaded font,OTS parsing error: OS/2: missing required table
”错误。本文将分析此错误并提供解决方案。
问题描述:
用户尝试使用schrift
库生成字体子集,代码如下:
include('schrift.php'); $font = new schrift('hywxinshu.ttf'); $data = $font->subset('abc hello world 中国'); file_put_contents('public/fonts/newfont1133.ttf', $data);
代码成功生成了字体文件,但浏览器加载时报错,提示缺少必要的OS/2
表。 问题并非schrift
库本身,而是生成的字体文件结构不完整。
解决方案:
使用更强大的字体处理库,确保生成的字体包含完整的OS/2
表。 以下示例代码使用一个未在原问题中提及的库(假设该库已正确安装和配置):
$fontfile = "example.ttf"; $subset = "abcdefghijklmnopqrstuvwxyz"; $font = Font::load($fontfile); // 使用更强大的字体处理库加载字体文件 if ($font instanceof Font_TrueType_Collection) { $font = $font->getFont(0); } $font->parse(); $font->setSubset($subset); $font->reduce(); $tmp = tempnam(sys_get_temp_dir(), "fnt"); $font->open($tmp, Font_Binary_Stream::modeWrite); $font->encode(array("OS/2")); // 关键步骤:确保OS/2表被编码 $font->close();
这段代码的关键在于使用了更健壮的字体处理库,并显式调用$font->encode(array("OS/2"))
确保OS/2
表被包含在最终的字体文件中。 选择合适的字体处理库,并正确处理字体文件结构,是解决此类问题的关键。 请注意,替换example.ttf
为您的字体文件路径,并根据所选库调整代码。