ureport2报表详细使用(一)-集成及配置

ureport2报表详细使用(一)-集成及配置一 报表简介 UReport2 是一款基于架构在 Spring 之上纯 Java 的高性能报表引擎 通过迭代单元格可以实现任意复杂的中国式报表 在 UReport2 中 提供了全新的基于网页的报表设计器 可以在 Chrome Firefox 等各种主流浏览器运行 不支持 IE 使用 UReport2 打开浏览器即可完成各种复杂报表的设计制作 二 主体功能 UReport2 支持创建数据源 添加数据集 并对数据集进行函数 表达式处理 参考 数据处理 UReport2 支持对数据集形成可视化报表 包

一、报表简介

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

二、主体功能

  1. UReport2支持创建数据源、添加数据集,并对数据集进行函数、表达式处理;(参考【数据处理】)
  2. UReport2支持对数据集形成可视化报表,包括饼状图、柱状图、曲线图等等(参考【图表展示】)

三、优缺点阐述

优点:

(1)开源、免费,集成即可使用;

(2)轻量级、易集成,工程中添加依赖即可进行集成使用;

(3)支持多函数处理,包括常用函数(sum、count、max、min、avg)、数学函数、字符串函数、日期函数等等;

(4)支持多种图表展示,包括饼状图、柱状图、曲线图、圆环图、雷达图、散点图等等;

缺点:

(1)工程在使用过程中经常出现空指针或者其他报错;

(2)UReport2部分功能不可用,包括导出及多条件表达式SQL查询等;

(3)支持数据源类型少,当前支持:mysql、SQLserver、oracle、db2等

四、集成及配置

UReport2的设计器是基于网页的,配置好一个项目,也就完成了报表设计器的安装。因为 UReport2是一款纯Java的报表引擎,所以它支持现在流行的所有类型J2EE项目,下面将具体介绍基于maven的SpringBoot工程如何集成UReport2 ,并基于当前工程进行一系列的数据处理及报表展示。

4.1 创建springboot工程

1、如果当前本地无springboot工程,提供下载地址:https://github.com/Sonlan/springboot-demo

2、基于已下载的springBoot工程,修改index.html文件内的外部js文件路径,将../修改为../../(原始路径不正确);

ureport2报表详细使用(一)-集成及配置

4.2 添加依赖

1、在springBoot工程的pom文件dependencies中添加依赖;

<dependency>  <groupId>com.bstek.ureport</groupId>  <artifactId>ureport2-console</artifactId>  <version>2.3.0-SNAPSHOT</version> </dependency> <dependency>  <groupId>com.bstek.ureport</groupId>  <artifactId>ureport2-core</artifactId>  <version>2.3.0-SNAPSHOT</version> </dependency>          <dependency>  <groupId>org.slf4j</groupId>  <artifactId>slf4j-api</artifactId>  <version>1.7.7</version> </dependency>

2、在springBoot工程的pom文件添加repositories;

<repositories>         <repository>             <id>snapshots</id>             <url>https://oss.sonatype.org/content/repositories/snapshots/</url>         </repository>         <repository>             <id>sonatype</id>             <url>https://oss.sonatype.org/content/groups/public/</url>         </repository> </repositories>

3、基于当前工程,创建webapp/WEB-INF目录,工程【main】目录右键【Directory】》输入【webapp】,基于webapp,继续新建directory》【WEB-INF】;

ureport2报表详细使用(一)-集成及配置

4.3 创建web.xml文件并配置

1、基于已新建【webapp】》【WEB-INF】目录,添加web.xml文件,点击【file】》【Project Structure】》【Facets】》【web】,新增web.xml文件及web resources directory;

ureport2报表详细使用(一)-集成及配置

说明: E:\company\idea\IdeaProjects\springboot-demo-master\src\main:为当前我工程的路径 E:\company\idea\IdeaProjects\springboot-demo-master\src\main\webapp\WEB-INF\web.xml(第5步) E:\company\idea\IdeaProjects\springboot-demo-master\src\main\webapp (第7步)

2、基于步骤6新增的web.xml文件,添加listener及context-param、servlet、servlet-mapping;

ureport2报表详细使用(一)-集成及配置

<listener>  <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <context-param>  <param-name>contextConfigLocation</param-name>  <param-value>classpath:ureport-console-context.xml</param-value> </context-param> <servlet>  <servlet-name>ureportServlet</servlet-name>  <servlet-class>com.bstek.ureport.console.UReportServlet</servlet-class> </servlet> <servlet-mapping>  <servlet-name>ureportServlet</servlet-name>  <url-pattern>/ureport/*</url-pattern> </servlet-mapping>

4.4 创建UreportConfig 文件

1、基于工程启动文件的父节点,创建子文件夹ureport》config,并创建UreportConfig 文件;

ureport2报表详细使用(一)-集成及配置

package com.song.configuration.ureport.config; import org.springframework.boot.autoconfigure.EnableAutoConfiguration; import org.springframework.boot.web.servlet.ServletRegistrationBean; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.ImportResource; import com.bstek.ureport.console.UReportServlet; /  *  Ureport2 配置类  * @author qiaolin  * @version 2018年5月9日  */ @ImportResource("classpath:ureport-console-context.xml") @EnableAutoConfiguration @Configuration @ComponentScan(basePackages = "com.song.configuration") public class UreportConfig {     @Bean     public ServletRegistrationBean buildUreportServlet(){         return new ServletRegistrationBean(new UReportServlet(), "/ureport/*");     } }

2、在配置途中,当缺少包时,需要根据提示自行添加、下载依赖,配置完成,点击resources目录,修改application.properties文件中关于mysql的配置,换成可用库(因为当前springboot工程是以一张user表为例的,所以当前连接的数据库中需要包含user表,囊括id、name、password字段),工程启动的端口号,默认是8080,此处已修改为18090;

ureport2报表详细使用(一)-集成及配置

#server server.port=18090 server.tomcat.uri-encoding=utf-8 #MySQL(当前仅为示例) spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3306/jeesite?characterEncoding=utf8 spring.datasource.username=root spring.datasource.password=

4.5 启动工程

1、当上述均配置完成,进入到启动文件Entry,右键点击【Run Entry】启动工程;

ureport2报表详细使用(一)-集成及配置

4.6 访问工程

工程成功启动,访问地址为: http://localhost:18090/ureport/designer

ureport2报表详细使用(一)-集成及配置

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/232395.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • sesvc.exe_alg是什么进程

    sesvc.exe_alg是什么进程今天公司的一台电脑一点右键就没有反应,通过任务管理发现每次启动都会有一个“Excel”进程,第一感觉就是中毒了,在网上找到了无暇解决方案杀毒方法:(切记:在操作过程中使用“右键->打开”,不可双击。)1.结束注册表中的fun.xls.exe的进程(建议选中fun.xls.exe->右键->转到进程,查找到“algsrvs.exe”单击它,再选择“…

    2022年10月3日
    4
  • python实现各大视频网站电影下载

    python实现各大视频网站电影下载一、前期准备有时候我们想下载自己喜欢的电影,但很多时候要么需要安装客户端才能下载,或者干脆不提供下载的服务,很是不爽,因此这里我们介绍使用python来实现网站的电影下载功能,凡是能在线观看的,都

    2022年7月3日
    27
  • struts2漏洞复现

    struts2漏洞复现struts2漏洞复现简介Struts2是apache项目下的一个web框架,普遍应用于阿里巴巴、京东等互联网、政府、企业门户网站Struts2是一个基于MVC设计思路的Web应用框架,它本质

    2022年7月1日
    25
  • vs单步调试及断点调试基本介绍(入门版详细图文介绍)

    vs单步调试及断点调试基本介绍(入门版详细图文介绍)简述:本文面向小萌新简单描述visualstudio2019下的基本调试技巧1:打断点,在侧栏点击一下,即可生成断点功能:在调试时可以运行到这一步之后停止如图2:进而可以单步调试,快捷键f11//注,电脑快捷键分软件和系统层快捷键//本人戴尔G3是通过Ese+fn键切换,不同电脑可能不一样注意窗口i的值,进入第一次for循环,i赋值为0之后,进入printf,然后返回f…

    2022年5月22日
    184
  • Spark和Hadoop的区别和比较[通俗易懂]

    Spark和Hadoop的区别和比较[通俗易懂]目录一、两者的各方面比较二、Spark相对Hadoop的优越性三、三大分布式计算系统Spark,是分布式计算平台,是一个用scala语言编写的计算框架,基于内存的快速、通用、可扩展的大数据分析引擎Hadoop,是分布式管理、存储、计算的生态系统;包括HDFS(存储)、MapReduce(计算)、Yarn(资源调度)一、实现原理的比较Hadoop和Spark都是并…

    2025年7月6日
    4
  • JAVA读取csv文件_java读取csv文件某一列

    JAVA读取csv文件_java读取csv文件某一列csv文件的介绍以下是来自百度百科的介绍逗号分隔值(Comma-SeparatedValues,CSV,有时也称为字符分隔值,因为分隔字符也可以不是逗号),其文件以纯文本形式存储表格数据(数字和文本)。纯文本意味着该文件是一个字符序列,不含必须像二进制数字那样被解读的数据。CSV文件由任意数目的记录组成,记录间以某种换行符分隔;每条记录由字段组成,字段间的分隔符是其它字符或字符串,最常见的是逗号或制表符。通常,所有记录都有完全相同的字段序列。通常都是纯文本文件。建议使用WORDPAD或是记事本来

    2025年6月1日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号