From aaf17321ff406a51d00e511e7e57e7ebdda149a0 Mon Sep 17 00:00:00 2001 From: liangzai <2440983361@qq.com> Date: Thu, 4 Dec 2025 13:28:03 +0800 Subject: [PATCH] fix --- internal/shared/pdf/font_manager.go | 39 +++++++++++++++++-- .../shared/pdf/pdf_generator_refactored.go | 13 ++++++- 2 files changed, 47 insertions(+), 5 deletions(-) diff --git a/internal/shared/pdf/font_manager.go b/internal/shared/pdf/font_manager.go index 70c3ce7..6602b47 100644 --- a/internal/shared/pdf/font_manager.go +++ b/internal/shared/pdf/font_manager.go @@ -94,8 +94,18 @@ func (fm *FontManager) tryAddFont(pdf *gofpdf.Fpdf, fontPath, fontName string) b 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("尝试添加字体", - 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), ) @@ -116,9 +126,26 @@ func (fm *FontManager) tryAddFont(pdf *gofpdf.Fpdf, fontPath, fontName string) b return false } - // gofpdf v2使用AddUTF8Font添加支持UTF-8的字体(使用绝对路径) - pdf.AddUTF8Font(fontName, "", absFontPath) // 常规样式 - pdf.AddUTF8Font(fontName, "B", absFontPath) // 粗体样式 + // 确保路径规范化(去除多余的路径组件) + absFontPath = filepath.Clean(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) @@ -127,7 +154,11 @@ func (fm *FontManager) tryAddFont(pdf *gofpdf.Fpdf, fontPath, fontName string) b fm.logger.Warn("字体加载后验证失败(测试文本宽度为0)", zap.String("font_path", absFontPath), zap.String("font_name", fontName), + zap.Float64("test_width", testWidth), ) + // 注意:即使验证失败,也可能在后续使用中成功 + // 因为 gofpdf 可能延迟加载字体 + // 但为了安全,我们还是返回 false return false } diff --git a/internal/shared/pdf/pdf_generator_refactored.go b/internal/shared/pdf/pdf_generator_refactored.go index 5f87d09..c38c1be 100644 --- a/internal/shared/pdf/pdf_generator_refactored.go +++ b/internal/shared/pdf/pdf_generator_refactored.go @@ -139,10 +139,21 @@ func (g *PDFGeneratorRefactored) generatePDF(product *entities.Product, doc *ent } // 生成PDF字节流 + // 注意:pdf.Output 时会重新访问字体文件,确保使用绝对路径 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) if err != nil { - // 错误已返回,不记录日志 + g.logger.Error("PDF Output失败", + zap.Error(err), + ) return nil, fmt.Errorf("生成PDF失败: %w", err) }