SpringBoot整合UReport2(报表开发)(配置类版)


前言

最近在公司里面要做对报表的修改,原项目用的是第三方报表软件,需要安装第三方软件,有水印,因此选择了基于Apache-2.0协议开源的中式报表引擎UReport2


一、UReport2是什么?

UReport2是一款高性能的架构在Spring之上纯Java报表引擎,通过迭代单元格可以实现任意复杂的中国式报表。
在UReport2中,提供了全新的基于网页的报表设计器,可以在Chrome、Firefox、Edge等各种主流浏览器运行(IE浏览器除外),打开浏览器即可完成各种复杂报表的设计制作。

二、使用步骤

当然该项目是基于springboot的,需要创建springboot工程

1.导入POM

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
  <groupId>mysql</groupId>
   <artifactId>mysql-connector-java</artifactId>
   <scope>runtime</scope>
</dependency>
<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
   <groupId>com.bstek.ureport</groupId>
   <artifactId>ureport2-console</artifactId>
   <version>2.2.9</version>
</dependency>
<!--连接池-->
<dependency>
   <groupId>com.alibaba</groupId>
   <artifactId>druid-spring-boot-starter</artifactId>
   <version>1.2.8</version>
</dependency>

2.添加context.properties

在resources目录下创建context.properties文件
内容为:

# 用于定义UReport2中提供的默认基于文件系统的报表存储目录
ureport.fileStoreDir=F:/ureportfiles

3.编写config配置类

@Configuration
//导入ureport-console-context.xml文件
@ImportResource("classpath:ureport-console-context.xml")
@Slf4j
public class ReportConfig implements BuildinDatasource {
//添加 report 的servlet
    @Bean
    public ServletRegistrationBean<Servlet> ureport2Servlet() {
        return new ServletRegistrationBean<>(new UReportServlet(), "/ureport/*");
    }
    //这一步省略了创建配置文件
    @Bean
    public UReportPropertyPlaceholderConfigurer UReportPropertyPlaceholderConfigurer(){
        UReportPropertyPlaceholderConfigurer propertyConfigurer=new UReportPropertyPlaceholderConfigurer();
        propertyConfigurer.setIgnoreUnresolvablePlaceholders(true);
        ClassPathResource pathResource=new ClassPathResource("context.properties");
        propertyConfigurer.setLocation(pathResource);
        return propertyConfigurer;
    }


//创建数据源,应该单独在一个配置类中,这里就写在同一个配置类中
    @Primary
    @Bean
    public DataSource businessDataSource(){
        DruidDataSource dataSource=new DruidDataSource();
        dataSource.setDriverClassName("com.mysql.jdbc.Driver");
        dataSource.setUrl("jdbc:mysql://localhost:3306/demo?useSSL=false&useUnicode=true&characterEncoding=UTF-8");
        dataSource.setUsername("root");
        dataSource.setPassword("root");
        return dataSource;
    }

    /**
     * 数据源名称
     **/
    @Override
    public String name() {
        return "ReportSource";
    }

    /**
     * 获取连接
     **/
    @Override
    public Connection getConnection() {
        try {
            return businessDataSource().getConnection();
        } catch (SQLException e) {
            log.error("Ureport 数据源 获取连接失败!");
            e.printStackTrace();
        }
        return null;
    }
}


省略的配置文件(因为用配置类配置类了,这里可以不用创建) ![如果不用配置类,那么用该配置文件也可以](https://img-blog.csdnimg.cn/ca898a98c219495fa0a4d1e5e0d5196a.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA6YW36YW355qE54ix5L2g,size_20,color_FFFFFF,t_70,g_se,x_16)

4.访问{ip}{端口}/ureport/designer

访问成功!
在这里插入图片描述

5.配置数据源

因为我们在配置类中配置了相关的source,此时可以直接查到

6.数据集配置

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

7.数据映射

映射前
映射前
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
映射后
映射后

8.过滤条件

在这里插入图片描述
过滤后
过滤后

9.行列操作

行列操作和excel差不多
选择单元格,右键
在这里插入图片描述

10.行类型

在这里插入图片描述

1.标题行

不算行内容,此时显示的话行内容是2,标题行只显示1次
在这里插入图片描述
在这里插入图片描述

2.重复表头

在这里插入图片描述
在这里插入图片描述

3.重复表尾

重复表尾,和表头差不多,只不过一个是头,一个是尾
在这里插入图片描述

4.总结行

在这里插入图片描述

总结

UReport2使用起来还是比较方便的,和现有的项目集成起来也比较简单

相关代码查看我的gitee库
相关代码gitee

  • 2
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Spring Boot整合UReport2可以通过以下步骤实现: 1. 引入UReport2的依赖 在pom.xml文件中添加以下依赖: ``` <dependency> <groupId>com.bstek.ureport</groupId> <artifactId>ureport2-core</artifactId> <version>2..6</version> </dependency> ``` 2. 配置UReport2的数据源 在application.properties文件中添加以下配置: ``` ureport.fileStoreDir=ureport_files ureport.ds.myds.driverClassName=com.mysql.jdbc.Driver ureport.ds.myds.url=jdbc:mysql://localhost:3306/test ureport.ds.myds.username=root ureport.ds.myds.password=root ``` 其中,ureport.fileStoreDir是UReport2报表文件存储的目录,ureport.ds.myds是数据源的配置,可以根据实际情况修改。 3. 创建UReport2报表 在resources目录下创建ureport文件夹,并在该文件夹下创建一个以ureport为后缀的文件,例如test.ureport.xml。 在该文件中可以使用UReport2提供的设计器创建报表。 4. 配置Spring Boot的Controller 在Spring Boot的Controller中注入UReportEngine对象,并在方法中调用UReportEngine的runReport方法生成报表。 ``` @RestController public class ReportController { @Autowired private UReportEngine uReportEngine; @GetMapping("/report") public void report(HttpServletResponse response) throws Exception { UReportFile reportFile = uReportEngine.getReportFile("test.ureport.xml"); UReport uReport = reportFile.parse(); Map<String, Object> parameters = new HashMap<>(); parameters.put("param1", "value1"); parameters.put("param2", "value2"); byte[] bytes = uReportEngine.generatePdf(uReport, parameters); response.setContentType("application/pdf"); response.getOutputStream().write(bytes); } } ``` 在上述代码中,调用了UReportEngine的getReportFile方法获取报表文件,然后调用parse方法解析报表文件,最后调用generatePdf方法生成PDF格式的报表。 5. 运行Spring Boot应用程序 在浏览器中访问http://localhost:808/report,即可生成报表并下载。 ### 回答2: Spring Boot是一种开源框架,可以用于快速构建基于Spring的企业级Web应用程序。而Ureport2是一个基于Java的开源报表引擎。将Spring BootUreport2结合起来,可以轻松构建出一个高效、稳定的报表系统。 首先,需要在Spring Boot的Maven依赖中添加Ureport2的依赖项,例如: ``` <dependency> <groupId>com.bstek.ureport</groupId> <artifactId>ureport2-console</artifactId> <version>2.8.14</version> </dependency> ``` 接下来,需要在Spring Boot配置Ureport2,主要包括以下步骤: 1. 配置Ureport2的工作目录,可以通过在application.properties中添加以下一行代码来实现: ``` ureport2.fileStoreDir=/ureport/filestore ``` 2. 配置Ureport2的资源访问路径,可以通过在application.properties中添加以下一行代码来实现: ``` ureport2.urConfigFile=classpath:ureport-context.xml ``` 3. 在Spring Boot中添加Ureport2的配置文件,需要在src/main/resources目录下创建ureport-context.xml文件,并在其中添加以下代码: ``` <bean id="ureportHtmlViewResolver" class="com.bstek.ureport.view.UreportHtmlViewResolver"> <property name="ureportTemplate" value="classpath:report/"/> </bean> ``` 4. 如果需要使用Ureport2的自定义扩展功能,可以在Spring Boot中添加相关扩展。 最后,还需在Spring Boot中编写相关代码,实现与Ureport2的数据交互。这部分代码需要遵循Ureport2的API规范,可通过Ureport2的文档获取相关信息。 总之,通过以上步骤,就可以轻松地将Spring BootUreport2整合起来,构建出高效稳定的企业级报表系统。 ### 回答3: Spring Boot是一个开源的Java Web框架,它提供了一种快速创建和部署Web应用的方式。Ureport2是一款强大的Java报表引擎,可以快速生成多种格式和样式的报表。将Spring BootUreport2整合可以使开发人员更加轻松地创建和管理报表,提高开发效率。 整合步骤如下: 1.添加依赖库 在pom.xml文件中添加以下依赖库: ```xml <dependency> <groupId>com.bstek.ureport</groupId> <artifactId>ureport2-core</artifactId> <version>2.6.6</version> </dependency> <dependency> <groupId>com.bstek.ureport</groupId> <artifactId>ureport2-web</artifactId> <version>2.6.6</version> </dependency> <dependency> <groupId>com.bstek.ureport</groupId> <artifactId>ureport2-engine</artifactId> <version>2.6.6</version> </dependency> ``` 2.配置文件 在Spring Boot配置文件application.properties中增加以下配置ureport.enabled=true ureport.report_home=/ureport2_home ureport.designer.enabled=true 其中,ureport.enabled设置为true,表示启用ureportureport.report_home表示报表文件存储的根路径;ureport.designer.enabled表示是否启用报表设计器。 3.定义报表控制器 在Spring Boot中定义控制器类来处理生成和展示报表,可以使用Spring Boot提供的@RestController注解来实现。 ```java @RestController @RequestMapping("report") public class ReportController { @Autowired private ReportService reportService; @GetMapping("/pdf") public void generatePdfReport(HttpServletRequest request, HttpServletResponse response) { // 获取报表模板文件 InputStream inputStream = this.getClass().getResourceAsStream("/ureport/test.ureport.xml"); // 获取报表数据 List<Map<String, Object>> dataList = reportService.getDataList(); // 生成PDF格式的报表文件 OutputStream outputStream = null; try { outputStream = response.getOutputStream(); UReportUtils.generatePdf(inputStream, dataList, outputStream); } catch (IOException e) { e.printStackTrace(); } finally { IOUtils.closeQuietly(outputStream); } } } ``` 在上述控制器类中,@GetMapping注解指定URL路径为“/report/pdf”,表示请求生成PDF格式的报表文件。通过报表模板文件和报表数据生成PDF格式的报表,并输出到response中。 4.定义报表服务类 在Spring Boot中定义服务类来获取数据并返回给报表控制器,可以使用Spring Boot提供的@Service注解来实现。 ```java @Service public class ReportService { public List<Map<String, Object>> getDataList() { // 从数据库或其他数据源获取数据 List<Map<String, Object>> dataList = new ArrayList<>(); Map<String, Object> data = new HashMap<>(); data.put("name", "张三"); data.put("age", 28); dataList.add(data); return dataList; } } ``` 在上述服务类中,getDataList方法从数据库或其他数据源获取数据,并返回给报表控制器使用。 整合完毕后,启动应用程序,访问“/report/pdf”即可生成PDF格式的报表文件并输出到浏览器中。Ureport2还支持多种格式和样式的报表输出,可以根据实际需求进行配置和使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值