Najlepsze rozwiązanie (dla lepszej wydajności), będzie wywoływać skompilowany raport.
można zobaczyć przykład poniżej
import java.io.IOException;
import java.util.HashMap;
import net.sf.jasperreports.engine.JREmptyDataSource;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JasperExportManager;
import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.JasperPrint;
public class PdfFromJasperFile {
public static void main(String[] args) throws JRException, IOException {
JasperPrint jasperPrint = JasperFillManager.fillReport("report.jasper", new HashMap<String, Object>(),
new JREmptyDataSource());
JasperExportManager.exportReportToPdfFile(jasperPrint, "sample.pdf");
}
}
Po 6 latach od opublikowania tego komunikatu [JRExport erParameter.OUTPUT_STREAM] (http://javadox.com/net.sf.jasperreports/jasperreports/5.1.0/net/sf/jasperreports/engine/JRExporterParameter.html#OUTPUT_STREAM) został uznany za przestarzały, wysłałem [odpowiedź] (http://stackoverflow.com/a/35698286/5292302), aby pokazać, jak można uzyskać tę odpowiedź w aktualnej wersji. –