fix
This commit is contained in:
@@ -94,8 +94,18 @@ func (fm *FontManager) tryAddFont(pdf *gofpdf.Fpdf, fontPath, fontName string) b
|
|||||||
absFontPath = fontPath
|
absFontPath = fontPath
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 再次确保是绝对路径(如果是相对路径,filepath.Abs可能返回错误)
|
||||||
|
if !filepath.IsAbs(absFontPath) {
|
||||||
|
if workDir, err := os.Getwd(); err == nil {
|
||||||
|
absFontPath = filepath.Join(workDir, absFontPath)
|
||||||
|
absFontPath, _ = filepath.Abs(absFontPath)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
fm.logger.Debug("尝试添加字体",
|
fm.logger.Debug("尝试添加字体",
|
||||||
zap.String("font_path", absFontPath),
|
zap.String("original_path", fontPath),
|
||||||
|
zap.String("absolute_path", absFontPath),
|
||||||
|
zap.Bool("is_absolute", filepath.IsAbs(absFontPath)),
|
||||||
zap.String("font_name", fontName),
|
zap.String("font_name", fontName),
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -116,9 +126,26 @@ func (fm *FontManager) tryAddFont(pdf *gofpdf.Fpdf, fontPath, fontName string) b
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
// gofpdf v2使用AddUTF8Font添加支持UTF-8的字体(使用绝对路径)
|
// 确保路径规范化(去除多余的路径组件)
|
||||||
pdf.AddUTF8Font(fontName, "", absFontPath) // 常规样式
|
absFontPath = filepath.Clean(absFontPath)
|
||||||
pdf.AddUTF8Font(fontName, "B", absFontPath) // 粗体样式
|
|
||||||
|
// gofpdf v2使用AddUTF8Font添加支持UTF-8的字体
|
||||||
|
// 重要:gofpdf 在 Output 时会重新访问字体文件
|
||||||
|
// 需要确保传入的路径是绝对路径,且路径分隔符使用系统正确的格式
|
||||||
|
// 在 Linux 下,路径应该以 / 开头
|
||||||
|
|
||||||
|
// 确保路径使用正确的分隔符(统一使用 /,gofpdf 内部会处理)
|
||||||
|
normalizedPath := filepath.ToSlash(absFontPath)
|
||||||
|
|
||||||
|
fm.logger.Debug("准备添加字体到gofpdf",
|
||||||
|
zap.String("abs_path", absFontPath),
|
||||||
|
zap.String("normalized_path", normalizedPath),
|
||||||
|
zap.String("font_name", fontName),
|
||||||
|
)
|
||||||
|
|
||||||
|
// AddUTF8Font 不返回错误,如果字体加载失败会在后续验证中发现
|
||||||
|
pdf.AddUTF8Font(fontName, "", normalizedPath) // 常规样式
|
||||||
|
pdf.AddUTF8Font(fontName, "B", normalizedPath) // 粗体样式
|
||||||
|
|
||||||
// 验证字体是否可用
|
// 验证字体是否可用
|
||||||
pdf.SetFont(fontName, "", 12)
|
pdf.SetFont(fontName, "", 12)
|
||||||
@@ -127,7 +154,11 @@ func (fm *FontManager) tryAddFont(pdf *gofpdf.Fpdf, fontPath, fontName string) b
|
|||||||
fm.logger.Warn("字体加载后验证失败(测试文本宽度为0)",
|
fm.logger.Warn("字体加载后验证失败(测试文本宽度为0)",
|
||||||
zap.String("font_path", absFontPath),
|
zap.String("font_path", absFontPath),
|
||||||
zap.String("font_name", fontName),
|
zap.String("font_name", fontName),
|
||||||
|
zap.Float64("test_width", testWidth),
|
||||||
)
|
)
|
||||||
|
// 注意:即使验证失败,也可能在后续使用中成功
|
||||||
|
// 因为 gofpdf 可能延迟加载字体
|
||||||
|
// 但为了安全,我们还是返回 false
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -139,10 +139,21 @@ func (g *PDFGeneratorRefactored) generatePDF(product *entities.Product, doc *ent
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 生成PDF字节流
|
// 生成PDF字节流
|
||||||
|
// 注意:pdf.Output 时会重新访问字体文件,确保使用绝对路径
|
||||||
var buf bytes.Buffer
|
var buf bytes.Buffer
|
||||||
|
|
||||||
|
// 在 Output 之前记录当前工作目录,以便调试路径问题
|
||||||
|
if workDir, err := os.Getwd(); err == nil {
|
||||||
|
g.logger.Debug("生成PDF前的环境信息",
|
||||||
|
zap.String("work_dir", workDir),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
err = pdf.Output(&buf)
|
err = pdf.Output(&buf)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
// 错误已返回,不记录日志
|
g.logger.Error("PDF Output失败",
|
||||||
|
zap.Error(err),
|
||||||
|
)
|
||||||
return nil, fmt.Errorf("生成PDF失败: %w", err)
|
return nil, fmt.Errorf("生成PDF失败: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user