前言
在本教程中,我们将学习如何在一个简单的Spring MVC Web应用中集成Jasper报表工具。教程涵盖的技术点有:报表自定义数据源的使用;报表渲染、呈现的配置与实现;iReport报表设计器的使用(报表模板设计)等。
开发环境准备
以下两种方式任选其一:
1. 在已有的SpringMVC项目环境中进行配置(要求项目可正常运行、调试);
2. 在eclipse中安装Spring的STS工具,然后新建一个Spring MVC Project(要求已配置好Maven环境);
项目依赖包
添加必须的jasperreports包依赖:
- <!-- iReport JasperReports -->
- <dependency>
- <groupId>net.sf.jasperreports</groupId>
- <artifactId>jasperreports</artifactId>
- <version>5.6.0</version>
- </dependency>
- <dependency>
- <groupId>org.codehaus.groovy</groupId>
- <artifactId>groovy-all</artifactId>
- <version>2.2.2</version>
- </dependency>
SpringMvc JasperReport整合
1、继承JasperReportsMultiFormatView类,并重写fillReport()方法,在该方法中增加setUrl()实 现,这样就可以在controller中指定要使用的报表模板文件了。这样做的好处是,只需要一个jasperReport配置文件,可以在 controller中动态的设定报表模板url。
- package com.sample.sping_ireport;
- import java.util.Map;
- import net.sf.jasperreports.engine.JasperPrint;
- import net.sf.jasperreports.engine.JasperReport;
- import org.springframework.web.servlet.view.jasperreports.JasperReportsMultiFormatView;
- public class CustomReportView extends JasperReportsMultiFormatView {
- private JasperReport report;
- public CustomReportView() {
- super();
- }
- protected JasperPrint fillReport(Map<String, Object> model) throws Exception {
- if (model.containsKey("url")) {
- setUrl(String.valueOf(model.get("url")));
- this.report = loadReport();
- }
- return super.fillReport(model);
- }
- protected JasperReport getReport() {
- return this.report;
- }
- }
2、在WEB-INF目录下创建报表视图配置文件jasper-views.xml,并指定解析器类为自定义的视图解析器类:
- <?xml version="1.0" encoding="UTF-8"?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="
- http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans-3.2.xsd">
- <bean id="reportView" class="com.sample.sping_ireport.CustomReportView">
- <!-- <property name="url" value="/WEB-INF/jasper/report2.jasper"/> -->
- <property name="reportDataKey" value="jrMainDataSource"/>
- </bean>
- </beans>
3、Jasper报表的渲染需要用到XmlViewResolver视图解析器,这样你的项目中就会存在多个视图解析器。需要注意的是,项目中如果 使用了多个视图解析器,则需要设置order的值来区分解析器的使用顺序,order值越小则越靠前。增加XmlViewResolver视图解析器的同 时,并指定其要解析的配置文件路径。
那么,需要在/WEB-INF/spring/appServlet/servlet-context.xml中增加下述配置:
- <!-- 注册XmlViewResolver,用于iReport & JasperReports报表生成 -->
- <beans:bean id="jasperReportResolver" class="org.springframework.web.servlet.view.XmlViewResolver">
- <beans:property name="order">
- <beans:value>0</beans:value>
- </beans:property>
- <beans:property name="location">
- <beans:value>WEB-INF/jasper-views.xml</beans:value>
- </beans:property>
- </beans:bean>
测试准备
1、创建JavaBeanPerson实体类:
- package com.sample.sping_ireport.model;
- import java.util.ArrayList;
- import java.util.List;
- /**
- * iReport测试bean: Person实体类
- * @author 许亮
- * @Create 2015-2-2 17:03:44
- */
- public class JavaBeanPerson {
- private String name; // 姓名
- private String sex; // 性别
- private int age; // 年龄
- private String hometown;// 籍贯
- private String phone; // 电话号码
- public JavaBeanPerson() {}
- public JavaBeanPerson(String name, String sex, int age, String hometown, String phone) {
- this.name = name;
- this.sex = sex;
- this.age = age;
- this.hometown = hometown;
- this.phone = phone;
- }
- /**
- get, set方法省略。。。。。。。。。。。
- */
- public static List<JavaBeanPerson> getList() {
- List<JavaBeanPerson> list = new ArrayList<JavaBeanPerson>();
- list.add(new JavaBeanPerson("Lily", "female", 22, "Hubei", "10086"));
- list.add(new JavaBeanPerson("Macro", "male", 33, "Beijing", "13800000000"));
- list.add(new JavaBeanPerson("Andy", "male", 44, "HongKong", "13812345678"));
- list.add(new JavaBeanPerson("Linder", "female", 28, "Guangxi", "18677778888"));
- list.add(new JavaBeanPerson("Jessie", "female", 26, "Gansu", "18219177720"));
- return list;
- }
- }
2、使用iReport设计报表模板,并编成.jasper二进制文件,并拷贝至\WEB-INF\jasper目录下:
3、编写Controller方法
- @RequestMapping(value = "/report", method = RequestMethod.GET)
- public String report(Model model) {
- // 报表数据源
- JRDataSource jrDataSource = new JRBeanCollectionDataSource(JavaBeanPerson.getList());
- // 动态指定报表模板url
- model.addAttribute("url", "/WEB-INF/jasper/spring_report.jasper");
- model.addAttribute("format", "pdf"); // 报表格式
- model.addAttribute("jrMainDataSource", jrDataSource);
- return "reportView"; // 对应jasper-views.xml中的bean id
- }
相关推荐
在本教程中,我们将学习如何在一个简单的Spring MVC Web应用中集成Jasper报表工具。教程涵盖的技术点有:报表自定义数据源的使用;报表渲染、呈现的配置与实现;iReport报表设计器的使用(报表模板设计)等
开始本示例之前,有必要先阅读我先前发布的《SpringMVC与iReport(JasperReports) 5.6整合开发实例》这篇博文,只有熟悉了SpringMVC与iReport的整合基础之后,才能更容易上手本示例教程,因为本示例的重点在于iReport...
dnSpy-net-win32-222.zip
和美乡村城乡融合发展数字化解决方案.docx
如何看待“适度宽松”的货币政策.pdf
NCO 3.0.18 64位
法码滋.exe法码滋2.exe法码滋3.exe
* GPS IMU经典15维ESKF松组合 * VRU/AHRS姿态融合算法 * 捷联惯导速度位置姿态解算例子 * UWB IMU紧组合融合 * 每个例子自带数据集
在现代社会生活与生产活动下,不可避免的会产生巨量且多样的垃圾。我国的人口和经济总量均位居世界前列,因此,必然面临着庞大数量的垃圾处理的难题。如何通过人工智能来对垃圾进行有效分类,成为当前备受关注的研究热点。本文为展开基于深度网络的垃圾识别与分类算法研究,先使用PyTorch框架中的transforms方法对数据进行预处理操作,后经过多次调参实验,对比朴素贝叶斯模型、Keras卷积神经网络模型、ResNeXt101模型的垃圾分类效果。确定最佳分类模型是ResNeXt101,该模型在GPU环境下的分类准确率达到了94.7%。最后利用postman软件来测试API接口,完成图片的在线预测。在微信开发者工具的基础上,利用一些天行数据的垃圾分类的API接口再结合最佳模型的API接口,开发出了一个垃圾分类微信小程序。本文的研究内容丰富和完善了垃圾图像分类的相关研究,也为后续的研究提供了一定的参考价值。
一、上位机简介 在单片机项目开发中,上位机也是一个很重要的部分,主要用于数据显示(波形、温度等)、用户控制(LED,继电器等),下位机(单片机)与 上位机之间要进行数据通信的两种方式都是基于串口的: USB转串口 —— 上位机和下位机通过USB转串口连接线直接相连进行数据交互 串口转WIFI(ESP8266)—— 上位机和下位机基于TCP/IP协议通过以太网或者WIFI传输数据 串口转蓝牙(HC-06)—— 不多用,暂不介绍 Windows上位机(EXE可执行程序),最早用VB语言开发,后来由于C++的发展,采用MFC开发,近几年,微软发布了基于.NET框架的面向对象语言C#,更加稳定安全,再配合微软强大的VS进行开发,效率奇高。 本文使用Visual Studio 2022作为开发环境,上位机开发主要有WPF框架与Winform框架,他们都是基于.NET框架 WPF需要C/S基础,使用XAML来构建应用UI,界面比较美观,但是内存开销大 Winform可以使用窗口控件来构建应用,比较简单易学 二、开发环境设置 1. 安装Visual Studio 首先,确保你已经
course_s4_ALINX_ZYNQ_MPSoC开发平台Linux驱动教程V1.04.pdf
基于JavaWeb的毕业季旅游一站式定制服务平台_88z1j4jp_208-wx-(1).zip
Apeaksoft Data Recovery for Mac v1.6.16
cms测试练习项目(linux系统部署),可以用来进行python的测试练手项目
数据集简介:大学录取结果分析 概述 大学录取结果数据集包含了有关大学录取过程的信息,包括关键变量,可用于分析不同学术因素与申请者是否被录取之间的关系。该数据集非常适合进行探索性数据分析、训练预测模型以及研究影响录取决策的因素。 数据集列描述 admit:指示申请者是否被录取(1=被录取,0=未录取)。 paes:申请者在高等教育能力测试(PAES)中获得的分数。 nem:中学教育成绩平均分,评分范围从1.0到7.0。 rank:申请者在其班级中的排名,数值越低表示排名越好。 数据集目的 本数据集旨在让用户探索学术指标(如PAES分数、GPA和排名)与大学录取成功率之间的关系。这可以用于: 开发预测模型:基于学术表现预测录取可能性。 识别趋势:找出影响录取的关键学术因素。 生成可视化图表:理解分数分布及录取结果的关系。 数据集规模 记录数:1813条。 列数:5列。
STM32F427+rtthread下的bootload 网口(webclient)+串口(ymodem)传输,代码无质量,谨慎使用
1. 用户管理功能 用户注册与登录:用户可以通过手机号、邮箱等方式注册账户,并且可以通过账号登录系统进行购票、查看历史订单等操作。 个人信息管理:用户可以查看和修改个人信息(如姓名、手机号、邮箱等),并进行密码重置等操作。 实名认证:部分电影院购票系统要求用户进行实名认证,确保用户身份的真实性。 2. 电影信息展示功能 电影排片查询:用户可以查看当前和未来一段时间内的电影排片表,包括电影名称、上映时间、影片时长、类型、导演、演员等详细信息。 电影详情页:点击具体电影后,用户可以查看电影的详细信息,如剧情介绍、影评、评分、预告片等内容。 电影评分与评论:用户可以查看其他观众的评分和评论,也可以对已观看的电影进行评分和评论。 3. 座位选择与预定功能 影厅座位图:系统展示每场次的影厅座位图,用户可以通过座位图查看当前座位的状态(如可选、已选、已售出、VIP座位等)。 座位选择:用户可以选择自己喜欢的座位,系统会实时更新座位的可用状态,避免重复选择。 座位偏好设置:用户可以设置自己的座位偏好,如选择前排、中排或后排,靠窗或靠过道等。 4. 电影票购买与支付功能 票价展示:系统会展示每个座位的
Bukkit-BETA1.8.1服务端核心
内容概要:本文详细介绍了快速排序算法的原理和在Go语言中的高效实现方法。首先解释了快速排序的基本思想和实现步骤,接着提供了Go语言中实现快速排序的核心代码,并讨论了性能优化策略。最后,通过具体的应用场景实例,展示了快速排序在实际项目中的高效应用。 适合人群:具备一定编程基础,特别是对Go语言感兴趣的开发人员。 使用场景及目标:①理解快速排序算法的基本原理和分治策略;②学习如何在Go语言中高效实现快速排序;③掌握快速排序在实际项目中的应用实例。 阅读建议:本文不仅详细讲解了快速排序的原理,还提供了具体的实现代码和优化策略,建议读者在阅读过程中尝试实现和调试代码,以便更好地理解和掌握相关知识点。