Springboot集成ureport2报表插件
最近在项⽬中需要⽤到报表功能,要求能灵活配置,⽽不是每次要⽣成报表都要写代码。调研了⽹上各种报表插件,发现各有千秋,但是最适合java项⽬的还是UReport2这个报表框架,我们项⽬后台框架是基于SpringBoot、SpringCloud框架搭建的微服务架构,下⾯介绍⼀下如何在Springboot架构中引⼊ureport2。
⼀.基础配置
1、我的spring boot版本是2.1.12, ureport2版本是2.2.9,mySQL链接版本是5.1.46,maven依赖如下:
<dependency>
<groupId>com.bstek.ureport</groupId>
<artifactId>ureport2-console</artifactId>
<version>2.2.9</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.46</version>
</dependency>
注:mySQL版本不能过⾼也不能太低,因spring boot版本不同,所以会在配置报表数据源的时候出现很多问题。
2、配置 UReport2 需要使⽤到的servlet,建UreportConfig配置类。
@Configuration
@ImportResource("l")
public class UreportConfig {
/**
* 进⾏注册Servlet
* 配置 UReport2 需要使⽤到的servlet
* @return
*/
@Bean
public ServletRegistrationBean buildUReportServlet() {
/*
* @param  servlet
* @param  urlMappings 值为“/ureport/*”的 urlMappings 是⼀定不能变的,否则系统将⽆法运⾏。
*/
return new ServletRegistrationBean(new UReportServlet(), "/ureport/*");
}
}
3、启动spring boot项⽬,ureport地址为ureport/designer。
4、修改保存报表默认路径。
在resource⽬录下新建ureport.properties⽂件,在⽂件中加⼊ureport.fileStoreDir=(实际路径,此路径要必须存在,否则会报错),修改完成后重启后保存的报表都会存在此路径下。
⼆、内置数据源配置
1、内置数据源需要实现ureport的内置接⼝BuildinDatasource。
@Component
public class UreportBuildDatasource implements BuildinDatasource {
private static final String NAME = "MyDataSource";
@Autowired
private DataSource dataSource;
@Override
public String name() {
return NAME;
}
@Override
springboot结构public Connection getConnection() {
try {
Connection();
} catch (SQLException e) {
throw new RuntimeException(e);
}
}
}
2、实现BuildinDatasource接⼝后,必须要确定⾃⼰的数据源已经配置完成。在l⽂件中加⼊数据源配置。
#数据库连接
spring:
datasource:
url: jdbc:mysql://localhost:3306/test_ureport?useUnicode=true&characterEncoding=UTF-8&useSSL=false
username: root
password: 123456
driver-class-name: sql.jdbc.Driver
配置完成后重启项⽬,打开报表,点击添加内置数据源链接,便可看见我们刚配置的默认数据源MyDataSource ,接下来就可以开始配置报表了。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。