PDF转图片乱码问题解决

问题描述

1、PDF转图片使用技术:pdfbox(具体代码百度随处可见)

2、问题概述:控制台报错,找不到字体,C:\Windows\FONTS\mstmc.ttf

10:52:06.162 [main] ERROR org.apache.pdfbox.pdmodel.font.FileSystemFontProvider - Could not load font file: C:\Windows\FONTS\mstmc.ttf

问题分析

由于找不到字体

问题解决

网上的各种方法都试了,比如:安装字体,代码解析的时候只用自定义字体,但是都不好使

最终通过查看源码,修改源码解决问题,重写org.apache.pdfbox.pdmodel.font.FontMapperImpl,增加本地存在字体,问题解决:

substitutes.put("STSong-Light", Arrays.asList("STFangsong"));

PDF转图片乱码问题解决_第1张图片

提示:该方法暂时只在本地开发测试通过,如果正式上生产环境,还需确认生产环境是否有STFangsong字体

 

代码(2020-05-25更新)

    好多人说用了这种方式还是没办法生成,补充一下用到的jar包和对应的代码,后续多多关照

pom依赖

        
            org.apache.pdfbox
            pdfbox
            2.0.17
        
        
            org.apache.pdfbox
            fontbox
            2.0.17
        
        
            org.apache.pdfbox
            pdfbox-tools
            2.0.17
        

代码实现

    /**
     * 转换全部的pdf
     * @param fileAddress 文件地址
     * @param filename PDF文件名
     * @param type 图片类型
     */
    public static void pdf2png(String fileAddress,String filename,String type) {
        // 将pdf装图片 并且自定义图片得格式大小
        File file = new File(fileAddress+"\\"+filename+".pdf");
        try {
            PDDocument doc = PDDocument.load(file);
            PDFRenderer renderer = new PDFRenderer(doc);
            int pageCount = doc.getNumberOfPages();
            for (int i = 0; i < pageCount; i++) {
                BufferedImage image = renderer.renderImageWithDPI(i, 144); // Windows native DPI
                // BufferedImage srcImage = resize(image, 240, 240);//产生缩略图
                ImageIO.write(image, type, new File(fileAddress+"\\"+filename+"_"+(i+1)+"."+type));
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    public static void main(String[] args) throws InterruptedException, IOException {
        PdfUtils.pdf2png("F:/", "hetong", "jpg");
//        PdfUtils.pdf2Image("F:/haha.pdf");

    }

 

你可能感兴趣的:(Java,PDF转图片,Could,not,load,font,file:,C:\W)