itext java_Java解决Itext pdf中文不显示问题

这篇博客介绍了如何在Java项目中使用Itext处理PDF时解决中文不显示的问题。作者通过引入itext-asian.jar,自定义了ChunkCssApplier,并提供了详细代码示例,避免修改源码。
摘要由CSDN通过智能技术生成

/** * AsianTest.java */import java.io.FileOutputStream;import java.io.IOException;import com.lowagie.text.*;import com.lowagie.text.pd

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

找了很多方法都没搞定,然后在网上看到了有个帖子说改源码解决这个问题,前面的文章《使用itext将html生成pdf中文换行问题解决方案》是使用itext2.0.8版本实现,这里使用itext5.4.2实现,这里用到了itext-asian.jar和xmlworker-5.4.2.j但是经过测试还是没有搞定。

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

第一部:

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 != chinessFont && isChinese(c

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值