java导出pdf不现实中文_Java解决Itext pdf中文不显示问题

这篇博客介绍了如何在Java使用Itext PDF库时解决中文不显示的问题,包括引入必要的依赖,重写ChunkCssApplier类以支持中文,并提供了一个示例代码详细解释了解决方案。
摘要由CSDN通过智能技术生成

[/** * AsianTest.java */ import java.io.FileOutputStream; import java.io.IOException; import com.lowagie.text.*; import com.lowagie.text.pdf.PdfWrit

最近在项目需要,需要将html内容转换成pdf的文件,采用itextpdf总是不显示中文。

找了很多方法都没搞定,然后在网上看到了有个帖子说改源码解决这个问题,[一、重写Breaker,添加中文识别// Decompiled by Jad v1.5.8e2. Copyright 2001 Pavel Kouznetsov.// Jad home page: http://kpdus.tripod.com/jad.html// Decompiler opt但是经过测试还是没有搞定。

并且个人不建议改源码,然后自己研究源码,借鉴了他的思路,可以不用改源码即可解决中文问题。

第一部:

maven 引入依赖的jar包

com.itextpdf

itextpdf

5.5.9

com.itextpdf.tool

xmlworker

5.5.9

com.itextpdf

itext-asian

5.2.0

根据ChunkCssApplier重写apply方法

@SuppressWarnings("deprecation")

public class MyChunkCssApplier extends ChunkCssApplier {

public static BaseFont chinessFont = null;

static {

try {

// 中文支持,需要引入 itext-asian.jar

chinessFont = BaseFont.createFont("STSongStd-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED);

} catch (Exception e) {

e.printStackTrace();

}

}

/**

* 判断是否存在中文

* @param str

* @return

*/

private static boolean isChinese(String str){

if(str == null ){

return false;

}

//存在中文

String regex = ".*[\\u4e00-\\u9faf].*";

return Pattern.matches(regex, str);

}

/**

*

* 重写apply方法

*/

@Override

public Chunk apply(Chunk c, Tag t) {

Font f = applyFontStyles(t);

// 增加此段代码 如果中文 ,则返回中文字体

if (null !

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值