如上图 ,表中需要的字段要在Fields里面进行新增配置
进行关联,其中Fields里的List是代码里的数组名字
Fields里定义的字段都要在对象里面定义,并赋值,才可以被插入报表.
引入依赖
<dependency>
<groupId>net.sf.jasperreports</groupId>
<artifactId>jasperreports</artifactId>
<version>6.13.0</version>
<exclusions>
<exclusion>
<groupId>com.lowagie</groupId>
<artifactId>itext</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>net.sf.jasperreports</groupId>
<artifactId>jasperreports-fonts</artifactId>
<version>6.13.0</version>
</dependency>
<dependency>
<groupId>com.lowagie</groupId>
<artifactId>itext</artifactId>
<version>2.1.7</version>
</dependency>
<dependency>
<groupId>com.itextpdf</groupId>
<artifactId>itextpdf</artifactId>
<version>5.5.0</version>
</dependency>
<dependency>
<groupId>com.itextpdf</groupId>
<artifactId>itext-pdfa</artifactId>
<version>5.5.0</version>
</dependency>
<dependency>
<groupId>com.pansenlink</groupId>
<artifactId>report-fonts</artifactId>
<version>1.0.0</version>
</dependency>
<dependency>
<groupId>com.itextpdf</groupId>
<artifactId>itext-asian</artifactId>
<version>5.2.0</version>
</dependency>
jasperReport导出实现:
eos.setDetailsList(new JRBeanCollectionDataSource(maps, false));
orderList.add(eos);
JasperPrint enquiryNoPrint = JasperFillManager.fillReport(enquiryRef, parameters, new JRBeanCollectionDataSource(orderList, false));
printList.add(enquiryNoPrint);
JRPdfExporter exporter = new JRPdfExporter();
exporter.setExporterInput(SimpleExporterInput.getInstance(printList));
exporter.setExporterOutput(new SimpleOutputStreamExporterOutput(outputStream));
exporter.exportReport();
具体实现方法
public void exportOrderPdf(Long id, BaseUserEntity user, ServletOutputStream outputStream) throws IOException, JRException {
//报表结果集查询
NewPurchaseOrderModel result = newPurchaseOrderService.purchaseOrderDetail(user, id);
List<OrderRequestDetailsModel> details = result.getPurOrderDetailsList();
PurOrder order = result.getOrders();
List<JasperPrint> printList = new ArrayList<>();
Map<String, Object> parameters = new HashMap<>(16);
try (InputStream enquiryRef = resourceLoader.getResource("classpath:report/enquiry_order.jasper").getInputStream()) {
List<Map<String, Object>> maps = new ArrayList<>();
List<Map<String, Object>> mapTaxed = new ArrayList<>();
EnquiryOrderSource eos = new EnquiryOrderSource();
eos.setEnquiryNo(order.getOrderNo());
Date createDate = order.getCreateDate();
eos.setCreateDate(format.format(createDate));
Map<String, Object> mapTax = new HashMap<>();
mapTax.put("untaxedAmount",changeF2Y(order.getUntaxedAmount()));
mapTax.put("totalAmount",changeF2Y(order.getTotalAmount()));
eos.setTotalData(new JRBeanCollectionDataSource(mapTaxed, false));
List<EnquiryOrderSource> orderList = new ArrayList<>();
for (OrderRequestDetailsModel detail : details) {
Map<String, Object> map = new HashMap<>();
map.put("materialsCode", detail.getMaterialsCode() == null ? "" : detail.getMaterialsCode());
map.put("materialsName", detail.getMaterialsName() == null ? "" : detail.getMaterialsName());
map.put("planDate", detail.getPlanDate() == null ? "" : format.format(detail.getPlanDate()));
map.put("materialsPrice", detail.getMaterialsPrice() == null ? "" : changeF2Y(detail.getMaterialsPrice()));
map.put("totalAmount", detail.getTotalAmount() == null ? "" : changeF2Y(detail.getTotalAmount()));
maps.add(map);
}
eos.setDetailsList(new JRBeanCollectionDataSource(maps, false));
orderList.add(eos);
JasperPrint enquiryNoPrint = JasperFillManager.fillReport(enquiryRef, parameters, new JRBeanCollectionDataSource(orderList, false));
printList.add(enquiryNoPrint);
JRPdfExporter exporter = new JRPdfExporter();
exporter.setExporterInput(SimpleExporterInput.getInstance(printList));
exporter.setExporterOutput(new SimpleOutputStreamExporterOutput(outputStream));
exporter.exportReport();
}
}