PDFBox ошибка: «org.apache.pdfbox.rendering.PDFRenderer не найден», когда он присутствует - PullRequest
1 голос
/ 03 апреля 2019

Я пишу плагин для Bitbucket Server, в котором мне приходится иметь дело с рендерингом PDF-файлов в изображения.Я использую PDFBox для этой цели.У меня есть метод pdfToPng, который будет вызван для выполнения обработки, и я изменил рендерер PDF аналогично тому, что предлагают примеры Apache.

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.pdmodel.graphics.color.PDColor;
import org.apache.pdfbox.rendering.PDFRenderer;
import org.apache.pdfbox.rendering.PageDrawer;
import org.apache.pdfbox.rendering.PageDrawerParameters;

import javax.imageio.ImageIO;
import java.awt.*;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;

public class PDFProcessor {

    private static Logger logger = LoggerFactory.getLogger(PDFProcessor.class);

    private static int _colorMode;

    /**
     * Convert a page of a PDF document into a colored PNG
     * @param color color to use, 0 - black, 1- red
     * @param fileName output file
     * @param pdfFile PDF to process
     * @throws IOException
     */
    public static void pdfToPng(int color, String fileName, File pdfFile) throws IOException{
        _colorMode = color;
        try (PDDocument pdfDoc = PDDocument.load(pdfFile)){
            logger.info("Begin PDF to PNG render for " + fileName);
            PDFRenderer renderer = new CustomPdfRenderer(pdfDoc);
            BufferedImage image = renderer.renderImageWithDPI(0,600);
            logger.info("Making PNG transparent...");
            BufferedImage transparentImage = ImageProcessor.makeTransparent(image,new Color(image.getRGB(0,0)));
            ImageIO.write(transparentImage, "PNG",new File(fileName+".png"));
            logger.info("Image processed successfully, writing to " + fileName + ".png");
        }
    }

    private static class CustomPdfRenderer extends PDFRenderer{
        CustomPdfRenderer(PDDocument document){
            super(document);
        }

        @Override
        protected PageDrawer createPageDrawer(PageDrawerParameters params) throws IOException{
            return new CustomPageDrawer(params);
        }
    }

    private static class CustomPageDrawer extends PageDrawer{
        CustomPageDrawer(PageDrawerParameters params) throws IOException{
            super(params);
        }

        @Override
        protected Paint getPaint(PDColor color) throws IOException{
            if ((color.toRGB() == (Color.BLACK.getRGB() & 0x00FFFFFF)) && (_colorMode == 1)){
                return Color.RED;
            }
            return super.getPaint(color);
        }
    }
}

Проект построен с использованием Maven, так как это когдаBitBucket использует для разработки плагинов.Однако, когда метод действительно вызывается, я получаю ClassNotFound исключение:

[INFO] Caused by: java.lang.NoClassDefFoundError: org/apache/pdfbox/rendering/PDFRenderer
[INFO]  at com.my-plugin.DiffManager.prepareDiff(DiffManager.java:99)
[INFO]  at com.my-plugin.DiffManager.doGet(DiffManager.java:67)
[INFO]  at com.my-plugin.DiffManager.doPost(DiffManager.java:84)
[INFO]  ... 33 common frames omitted
[INFO] Caused by: java.lang.ClassNotFoundException: org.apache.pdfbox.rendering.PDFRenderer not found by com.my-plugin.integrationPlugin [219]
[INFO]  at org.apache.felix.framework.BundleWiringImpl.findClassOrResourceByDelegation(BundleWiringImpl.java:1532)
[INFO]  ... 36 common frames omitted

Как видите, я импортировал класс PDFRenderer.My pom.xml также содержит правильное определение зависимости:

<dependency>
    <groupId>org.apache.pdfbox</groupId>
    <artifactId>pdfbox</artifactId>
    <version>2.0.14</version>
    <scope>provided</scope>
</dependency>

Почему Java не может найти класс PDFRenderer?Другие зависимости, которые объявлены таким образом, никогда не имеют этой проблемы.

1 Ответ

2 голосов
/ 03 апреля 2019

Вы используете зависимость pdfbox с <scope>provided</scope>.Кого вы ожидаете, чтобы обеспечить эту зависимость, когда это необходимо?Контейнер приложения, такой как Tomcat?

Я предлагаю удалить строку scope, чтобы зависимость была неявно compile scope, что должно решить проблему для вас.

Пожалуйста, обратитесь ктакже Область видимости Maven docs , в которой говорится:

  • compile - Это область по умолчанию, используемая, если ни одна не указана.Зависимости компиляции доступны во всех путях классов проекта.

  • provided - Это очень похоже на компиляцию, но указывает, что вы ожидаете, что JDK или контейнер предоставят зависимость во время выполнения.

...