springboot整合UReport2

本文详细介绍了如何在SpringBoot项目中集成UReport2报表工具,包括项目创建、依赖配置、数据源设置及报表设计页面访问等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、首先新建一个springboot项目

可以用idea直接新建,也可以在spring-boot官方提供的生成器生成项目,生成地址是:https://start.spring.io/

2、配置pom.xml

<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.1.1</version>
        </dependency>

        <!--ureport-->
        <dependency>
            <groupId>com.syyai.spring.boot</groupId>
            <artifactId>ureport-spring-boot-starter</artifactId>
            <version>2.2.9</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
    </dependencies>

3、配置application.yml配置文件

spring:
  type: com.alibaba.druid.pool.DruidDataSource
  datasource:
    url: jdbc:mysql://localhost:3306/ureport?useUnicode=true&characterEncoding=UTF8&autoReconnect=true&useSSL=false&serverTimezone=Asia/Shanghai
    username: root
    password: 123456
    driver-class-name: com.mysql.cj.jdbc.Driver
  main:
    allow-bean-definition-overriding: true

logback:
  logPath: /ureport/log
  level: INFO

server:
  port: 8080

4、编写config代码类,用于配置UReport2

import com.bstek.ureport.console.UReportServlet;
import com.bstek.ureport.definition.datasource.BuildinDatasource;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.ImportResource;

import javax.annotation.Resource;
import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.SQLException;

@ImportResource("classpath:ureport-console-context.xml")//不加项目能够启动但是会导致加载数据源报错或加载不了
@Configuration
public class UreportConfig implements BuildinDatasource {
    @Resource
    DataSource dataSource;
    private Logger log = LoggerFactory.getLogger(getClass());

    @Bean //定义ureport的启动servlet
    @SuppressWarnings("unchecked")
    public ServletRegistrationBean ureportServlet(){
        ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new UReportServlet());
        servletRegistrationBean.addUrlMappings("/ureport/*");
        return servletRegistrationBean;
    }
    @Override
    public String name() {
        return "myUReportDatasource";
    }

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

}

5、启动项目,打开ureport设计页面

访问:http://localhost:8080/ureport/designer

即可打开报表设计页面

 

UReport2 是一个基于 JasperReport 的开源报表工具,它的特点是支持在线设计报表、动态数据源、可视化配置等功能。Spring Boot 是一个快速开发框架,它可以帮助我们快速搭建 Web 应用程序。下面是 Spring Boot 整合 UReport2 的步骤。 1. 添加 UReport2 的依赖 在 pom.xml 文件中添加以下依赖: ```xml <dependency> <groupId>com.bstek.ureport</groupId> <artifactId>ureport2-console</artifactId> <version>2.8.10</version> </dependency> ``` 2. 配置 UReport2 在 application.properties 文件中添加以下配置: ```properties # UReport2 配置文件 ureport.config.location=classpath:ureport.xml ureport.temp.path=/tmp/ureport/ ureport.export.path=/tmp/ureport/export/ ureport.debug=true ``` 其中,ureport.config.location 指定 UReport2 的配置文件路径,ureport.temp.path 指定 UReport2 的临时文件路径,ureport.export.path 指定 UReport2 的导出文件路径,ureport.debug=true 表示启用 UReport2 的调试模式。 3. 配置数据源 在 application.properties 文件中添加以下配置: ```properties # 数据源配置 spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false spring.datasource.username=root spring.datasource.password=123456 ``` 其中,spring.datasource.driver-class-name 指定数据库驱动程序,spring.datasource.url 指定数据库连接地址,spring.datasource.username 和 spring.datasource.password 分别指定数据库用户名和密码。 4. 编写 UReport2 配置文件 在 resources 目录下创建 ureport.xml 文件,配置数据源和报表存储方式: ```xml <?xml version="1.0" encoding="UTF-8"?> <ureport> <!-- 配置数据源 --> <data-sources> <data-source name="dataSource" class="com.alibaba.druid.pool.DruidDataSource"> <property name="driverClassName">#{jdbc.driverClassName}</property> <property name="url">#{jdbc.url}</property> <property name="username">#{jdbc.username}</property> <property name="password">#{jdbc.password}</property> </data-source> </data-sources> <!-- 配置报表存储方式 --> <report-storage> <report-storage-in-file path="/tmp/ureport/files" /> </report-storage> </ureport> ``` 其中,data-source 标签用于配置数据源,report-storage 标签用于配置报表存储方式。 5. 创建报表模板 在 resources 目录下创建 report.ureport.xml 文件,用于定义报表模板。 6. 编写 Spring Boot Controller 在 Spring Boot 应用程序中创建一个 Controller,用于处理报表请求: ```java @RestController public class ReportController { @Autowired private ReportManager reportManager; @RequestMapping("/report") public void report(HttpServletRequest request, HttpServletResponse response) throws Exception { String id = request.getParameter("id"); ReportClient reportClient = reportManager.createReportClient("file:/tmp/ureport/files/" + id + ".ureport.xml", request, response); reportClient.execute(); } } ``` 其中,reportManager 是 UReport2 的报表管理器,用于创建报表客户端,report 方法用于处理报表请求,根据请求参数 id 加载对应的报表模板,并生成报表。 7. 运行应用程序 启动 Spring Boot 应用程序,并访问 http://localhost:8080/report?id=report,即可生成报表。其中,report 是报表模板的名称,可以根据实际情况进行修改。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值