Я пишу плагин для 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
?Другие зависимости, которые объявлены таким образом, никогда не имеют этой проблемы.