关于HTML转PDF中文无法显示的问题

如下图,输出后的PDF中,除了英文数字符号,剩下的字符全部不显示

HTML代码

<h1>1详情2</h1>

<h1>3Row and4 Col5 样式实现6</h1>

<div class="row">
    <div class="col">1--</div>
    <div class="col">2--</div>
    <div class="col">3查询 [2022] 002 号</div>
    <div class="col">4--</div>
    <div class="col">55</div>
</div>

输出后的PDF页面
在这里插入图片描述
HTML转PDF代码

public static OutputStream htmlToPdf(String htmlContent, String font,OutputStream os) throws IOException, com.lowagie.text.DocumentException {
        ITextRenderer renderer = new ITextRenderer();
        ITextFontResolver fontResolver = renderer.getFontResolver();
        // 设置字体
        fontResolver.addFont(font, BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED);
        renderer.setDocumentFromString(htmlContent);
        renderer.layout();
        renderer.createPDF(os);
        return os;
    }

为了解决这个问题,尝试用最简单的页面不断试错。

解决办法:在标签中声明一个支持中文的字体

<body style="font-family: SimSun">

为了确保在HTML中使用的字体在PDF中能够正确显示。可以尝试使用其他常见的中文字体,如SimSun, 宋体, Arial Unicode MS等。

需要注意的是,要在后端代码中声明字体:fontResolver.addFont(font, BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED);

利用截图的方法生成pdf文件:

var targetWindow = document.querySelector('#targetWindow');
html2canvas(targetWindow, {
	onrendered: function(canvas) {
		// 显示截图
		// var screenshotDiv = document.getElementById('screenshot');
		// screenshotDiv.appendChild(canvas);
		var pdf = new jspdf.jsPDF(); // 更新这里的变量名为 jspdf.jsPDF()
		pdf.addImage(canvas, 'JPEG', 0, 0, 210, 297); // A4 尺寸
		pdf.save('page-content.pdf');
	}
});
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1、解决中文问题 2、附字体 3、动态html拼接pdf public static void htmlCodeComeString(String linkcss,String htmlCode, String outputFile,String title) throws Exception { OutputStream os = new FileOutputStream(outputFile); ITextRenderer renderer = new ITextRenderer(); renderer.setDocumentFromString(getConversionHtmlCode(linkcss,htmlCode,title)); ITextFontResolver fontResolver = renderer.getFontResolver(); URL fontPath = ItextUtil.class.getResource("simsun.ttc"); fontResolver.addFont(fontPath.toString(), BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED); // 解决图片的相对路径问题 // renderer.getSharedContext().setBaseURL("file:/F:/teste/html/"); renderer.layout(); renderer.createPDF(os); System.out.println("======换成功!"); os.close(); os.flush(); } public static void main(String[] args) { ItextUtil itextUtil = new ItextUtil(); String html = ""; html += ""; html += "企业信息"; html += " "; html += " "; html += " 登记日期"; html += " 2006-04-28"; html += " "; html += " "; html += " 纳税人编号"; html += " HSJIHKS002"; html += " "; html += " "; html += " 有效标志"; html += " Y"; html += " "; html += " "; html += " 社会信用代码"; html += " 916101317H"; html += " "; html += " "; html += " 评估机关代码"; html += " 盛世"; html += " "; html += " "; html += " 工商注销日期"; html += " 2006-04-28"; html += " "; html += " "; html += ""; String outputFile = "D:\\pdf\\aa.pdf"; try { itextUtil.htmlCodeComeString("",html,outputFile,""); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println("生成结束!!!"); }
你可以尝试使用 iTextPDF 进行 HTML PDF,但需要确保正确处理中文字符集。以下是一些可能的解决方案: 1. 确保字体正确:在将 HTML 换为 PDF 之前,确保所使用的字体包含中文字符集。可以使用 `FontFactory.registerDirectories()` 方法来注册字体目录,或者手动指定使用的字体。 例如,可以使用以下代码注册字体目录: ```java FontFactory.registerDirectories(); ``` 或者手动指定字体: ```java Font font = FontFactory.getFont("SimSun", BaseFont.IDENTITY_H, BaseFont.EMBEDDED); ``` 2. 设置字符编码:在将 HTML 换为 PDF 之前,设置正确的字符编码。可以使用 `Meta` 标签或设置 `Content-Type` 头来指定字符编码。 例如,在 HTML 中添加以下 `Meta` 标签: ```html <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> ``` 或在代码中设置 `Content-Type` 头: ```java response.setContentType("text/html; charset=UTF-8"); ``` 3. 检查字体嵌入:确认生成的 PDF 中是否正确地嵌入了所需的字体。可以使用 Adobe Acrobat 等 PDF 阅读器来检查字体嵌入情况。 4. 使用中文字体文件:如果默认字体无法正确显示中文,可以尝试使用自定义中文字体文件。将字体文件放置在项目目录中,并在代码中指定使用该字体。 ```java Font font = FontFactory.getFont("path/to/customFont.ttf", BaseFont.IDENTITY_H, BaseFont.EMBEDDED); ``` 这些解决方案应该能够帮助你在 iTextPDF 中正确显示中文字符集。如果问题仍然存在,可以尝试参考 iTextPDF 的文档或寻求其他开发者的帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值