解决越南语PDF导出乱码问题

这几天在做一个项目时,包含越南语,导出Pdf文件时,有些字符丢失或显示不完整,经过各种AI搜索整理后,终于可以正常显示,记录如下:

1. 先准备字体

  1. 下载 arial-unicode-ms.ttf
  2. 在网站根目录新建一个文件夹 fonts
  3. 把字体放进去
  4. 右键字体 → 属性 → 复制到输出目录:如果较新则复制

2. WebForm 后台代码,用ashx

csharp

运行

复制代码
using System;
using System.IO;
using iTextSharp.text;
using iTextSharp.text.pdf;

public partial class TestPdf : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        try
        {
            // ========= WebForm 正确路径 =========
            string basePath =  HttpContext.Current.Server.MapPath("~/");
            string fontPath =  HttpContext.Current.Server.MapPath("~/fonts/arial-unicode-ms.ttf");
            string pdfPath = Path.Combine(basePath, "Result.pdf");

            // ========= 生成PDF(流自动释放,绝不占用文件) =========
            using (FileStream fs = new FileStream(pdfPath, FileMode.Create))
            {
                Document doc = new Document(PageSize.A4, 20, 20, 20, 20);
                PdfWriter.GetInstance(doc, fs);

                doc.Open();

                // ========= 【核心:越南语100%显示】 =========
                BaseFont bf = BaseFont.CreateFont(
                    fontPath,
                    BaseFont.IDENTITY_H,
                    BaseFont.EMBEDDED
                );
                Font font = new Font(bf, 14);

                // ========= 你的越南语(完整显示) =========
                string vietText = "CÔNG TY TNHH THƯƠNG MẠI TƯ VẤN CHUYÊN NGHIỆP TRÍ TUỆ";
                doc.Add(new Paragraph(vietText, font));

                doc.Close();
            }

            Response.Write("PDF生成成功:" + pdfPath);
        }
        catch (Exception ex)
        {
            Response.Write("错误:" + ex.Message);
        }
    }
}

如果是Winform,把取地址的语句改一下:

cs 复制代码
// 程序运行目录
        string basePath = AppDomain.CurrentDomain.BaseDirectory;

        // PDF 保存路径
        string pdfPath = Path.Combine(basePath, "Test.pdf");

        // 字体路径(必须和 exe 在一起)
        string fontPath = Path.Combine(basePath, "arial-unicode-ms.ttf");

✅ 说明

  1. 越南语特殊字符 Ư Đ Ạ Ệ 全部正常显示
  2. PDF 能正常打开,不损坏
  3. 流自动释放,不会文件被占用
  4. WebForm 专用路径 Server.MapPath 不报错
  5. 不依赖系统字体
相关推荐
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠3 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾3 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
weixin_397574093 天前
PDF复杂表格的1:1还原引擎:跨页表格自动拼接技术实战
大数据·人工智能·pdf
Metaphor6923 天前
使用 Python 将 PDF 转换为 HTML
python·pdf·html
Qres8213 天前
算法复键——树状数组
数据结构·算法
2601_961845153 天前
粉笔行测5000题电子版|pdf|解析
pdf·新媒体运营·github·个人开发·内容运营·规格说明书·极限编程
Sour3 天前
PDF翻译卡住不动怎么办?扫描件、OCR 和大文件排查清单
前端·pdf·ocr
牛油果子哥q3 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒3 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode