一、报表简介

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文件路径,将../修改为../../(原始路径不正确);

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】;

4.3 创建web.xml文件并配置

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

说明:
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;

<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 文件;

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 {@Beanpublic ServletRegistrationBean buildUreportServlet(){return new ServletRegistrationBean(new UReportServlet(), "/ureport/*");}}

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

#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=123456

4.5 启动工程

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

4.6 访问工程

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

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

  1. ureport2报表详细使用(四)-数据处理

    七.数据处理 1)回到报表设计界面,查看表格具体参数配置,当前所有字段默认聚合方式均为:分组: 聚合方式 用途 列表(select) 对数据不作处理完整展示 分组(group) 将数据相同的作为一组进 ...

  2. ureport2报表详细使用(五)-查询表单设计

    八.查询表单设计 查询表单设计主要是针对于使用表达式类型的SQL而言的,具体使用如下: 1)保存当前报表,点击左上角保存按钮: 2)浏览器地址输入: http://localhost:18090/ur ...

  3. ureport2报表详细使用(三)-添加数据集

    六.添加数据集 6.1 配置数据源 1)设计报表界面,选择右侧数据源,点击 图标,输入相关数据源相关连接信息,: 说明:此处数据作为示例,具体以用户当前存在的数据库为准. 数据源名称:test 连接用 ...

  4. UReport2 报表设计器 在线表格

    UReport2官网 一.UReport2报表设计器         UReport2是一个开源的可视化报表设计器,功能强大,操作简单,可以实现复杂的报表统计,有各种各样的导出和打印功能,支持导入Ex ...

  5. 在SpringBoot项目中使用Ureport2报表工具

    SpringBoot项目中使用Ureport2报表工具 1.在spring boot项目中使用Ureport2报表工具,首先需要在maven的pom.xml中添加Ureport2的依赖. <!- ...

  6. 一文搞定:SpringBoot 集成 Apollo 配置中心

    公众号后台回复"面试",获取精品学习资料 扫描下方海报了解专栏详情 本文来源: http://www.mydlq.club/article/42/ <Java工程师面试突击( ...

  7. UReport2报表图片显示

    UReport2报表图片显示 看UReport2图片加载的源码 package com.bstek.ureport.provider.image;import java.io.FileInputStr ...

  8. Android开发教程 - 使用Data Binding(二)集成与配置

    本系列目录 使用Data Binding(一)介绍 使用Data Binding(二)集成与配置 使用Data Binding(三)在Activity中的使用 使用Data Binding(四)在Fr ...

  9. s2sh集成dataSource配置无效的问题 -Access denied for user 'sa'@'localhost'

    s2sh集成dataSource配置无效的问题 -Access denied for user 'sa'@'localhost' 博客分类: j2ee s2sh web架构 strutshiberna ...

  10. 超级详细的手写webpack4配置来启动vue2项目(附配置作用)

    基础目录结构以及各个文件的作用 初始npm项目 npm init 一路回车,一律使用默认的npm项目配置 package.json修改scripts 如下: {"name": &q ...

最新文章

  1. AI Studio 不同环境下的执行速度
  2. Java异常机制及异常处理建议
  3. mysql 目录武沛齐_MySQL数据表中的数据操作
  4. mvnForum1.2.2在Eclipse中的部署
  5. python用import xlwt出现红字_如何用python处理excel
  6. 【引用】内网安全数据保密技术分析与比较
  7. 做一个略调皮的个人主页--结构篇
  8. GJB用于试验的计算机软件,GJB9001C-2017版标准培训课件.ppt
  9. win7系统中安装破解版Charles教程 基本使用方法汇总
  10. Linux刻录系统文件ISO到光盘
  11. K_A11_002 基于STM32等单片机驱动DS18B20串口与OLED0.96双显示
  12. PointNet: Deep Learning on Point Sets for 3D Classification and Segmentation
  13. Android应用接入招商一网通
  14. 【ZOJ 4062】Plants vs. Zombies
  15. c语言程序设计 a,C语言程序设计试题A
  16. 第一人称游戏技术 - 实现在高低不平的3D地形上行走效果
  17. 点云数据处理合集(二)点云数据处理
  18. 优秀团队建设--美国式团队(ppt)
  19. verilog脉冲产生高电平
  20. Kerloud 飞车在线控制C++教程

热门文章

  1. 界面控件DotNetBar for WinForms使用教程:LayoutControl布局与通用代码设置(三)
  2. KVM 虚拟化技术 理论详解
  3. redis安装与配置
  4. flask基于保利威做视频认证
  5. Python数据挖掘实战——贝叶斯分类算法
  6. 上传,修改头像的使用
  7. java static 详解
  8. laravel 图片流_laravel 做图片的缩略图 踩坑
  9. 浏览器点击跳转链接弹出下载框的可能原因
  10. linux 3t 硬盘无法识别,希捷(3T)硬盘故障处理备忘