无法使用pdfbox打印任何内容

时间:2013-02-04 18:20:37

标签: java pdf printing pdfbox

我正在尝试使用apache的pdfbox打印pdf文件,因此我创建了一个负责打印任何pdf文件的控制器。正如您在下面的代码中看到的那样,控制器只有一个带有文件路径参数的公共方法。控制器无一例外地运行,但它不打印任何东西:

public class ControladorImpressao {

    @Value("${nome.impressora}")
    private String nomeImpressora;
    private PDDocument arquivoPDF;
    private Logger logger = LoggerFactory.getLogger(this.getClass());

    public boolean imprimir(String arquivo) {
        try {
            carregarArquivoPDF(arquivo);
            iniciarImpressao(arquivo);
            return true;
        } catch (Exception e) {
            logger.error("Erro ao tentar imprimir documento!",e);
        }
        return false;
    }

    private void carregarArquivoPDF(String arquivo) {
        try {
            arquivoPDF=new PDDocument();
            arquivoPDF.load(arquivo);
        }
        catch (Exception e) {
            logger.error("Erro ao abrir pdf!",e);
        }
    }

    private void iniciarImpressao(String nomeArquivo) throws PrinterException {
        PrintService impressora=recuperarImpressora();
        PrinterJob job = PrinterJob.getPrinterJob();
        job.setPrintService(impressora);
        job.setJobName(nomeArquivo);
        job.setCopies(1);
        arquivoPDF.silentPrint(job);
    }

    private PrintService recuperarImpressora() {
        PrintService[] printServices = PrinterJob.lookupPrintServices();
        for (int count = 0; count < printServices.length; ++count) {
            if (nomeImpressora.equalsIgnoreCase(printServices[count].getName())) {
                return printServices[count];
            }
        }
        return null;
    }
}

我正在使用带有maven的pdfbox版本1.7.0:

 <dependency>
        <groupId>org.apache.pdfbox</groupId>
        <artifactId>pdfbox</artifactId>
        <version>1.7.0</version>
 </dependency>

我做错了什么?

1 个答案:

答案 0 :(得分:1)

解决了改变我实例化PDDocument(现在我正在使用静态加载)的方式并改变我使用PrinterJob的方式的问题:

public class ControladorImpressao {

    @Value("${nome.impressora}")
    private String nomeImpressora;
    private PDDocument arquivoPDF;
    private Logger logger = LoggerFactory.getLogger(this.getClass());

    public boolean imprimir(String arquivo) {
        try {
            arquivoPDF=PDDocument.load(new File(arquivo));
            PrinterJob job = PrinterJob.getPrinterJob();
            job.setPrintService(recuperarImpressora());
            job.setJobName(arquivo);
            job.setPageable(arquivoPDF);
            job.print();
            return true;
        } catch (Exception e) {
            logger.error("Erro ao tentar imprimir documento!",e);
        }
        return false;
    }

    private PrintService recuperarImpressora() {
        PrintService[] printServices = PrinterJob.lookupPrintServices();
        for (int count = 0; count < printServices.length; ++count) {
            if (nomeImpressora.equalsIgnoreCase(printServices[count].getName())) {
                return printServices[count];
            }
        }
        return null;
    }
}

我注意到的一个有趣的事情是,如果使用静态加载方法,我使用:

arquivoPDF=new PDDocument();
arquivoPDF.load(arquivo);

我仍然无法打印任何东西,可能问题出在load方法中。 感谢@yms,如果他没有告诉我PdfBox文档中的注释,可能我会去另一条路径。