Springboot构建Echarts数据可视化

本文涉及的产品
可视分析地图(DataV-Atlas),3 个项目,100M 存储空间
简介: pring boot集成了tomcat等容器,效率更高,要实现数据的可视化,需要构建spring Boot框架架构web项目。同时使用注意的方式,就可以轻松建立前端访问路径与后端controller方法的映射关系,而不用像servlet一样维护繁琐的xml映射配置表。

pring boot集成了tomcat等容器,效率更高,要实现数据的可视化,需要构建spring Boot框架架构web项目。同时使用注意的方式,就可以轻松建立前端访问路径与后端controller方法的映射关系,而不用像servlet一样维护繁琐的xml映射配置表。


Springboot入门学习: Spring入门篇_Spring入门视频教程-慕课网

Springboot官网: Spring Boot

Springboot学习: SpringBoot是什么?SpringBoot的优缺点有哪些?

下面咱看看如何使用工具IDEA利用Spring Boot构建web项目。

1. File > new > Project >进入如下页面:

image.png

image.png

image.png

image.png


点击完成后,会自动去下载对应的maven依赖。所以注意,这里需要你提前安装好maven。来看一下我的maven配置:

File > Settings > Build,Execution,Deployment > Build Tools > Maven

image.png

-Xms128m -Xmx512m -Duser.language=zh -Dfile.encoding=UTF-8

image.png


进入工程后,删除无用的文件mvnw、mvnw.cmd、.mvn文件夹

创建一个Controller:

image.png

package com.crn.spark.web;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class HelloController {
@RequestMapping(value = "/hello",method = RequestMethod.GET)
public String sayHello(){
return "Spring Boot... Hello World!";
}
}


启动:

选中WebApplication,鼠标点击右键:

启动日志:

image.png

前端访问测试:

http://localhost:8080/hello

访问路径中缺少,项目名称,再丰富一下配置文件:

image.png

观察启动日志,port已经发生变化:

再次进行访问测试:

http://localhost:8089/crn/hello

3. 使用Echarts构建静态数据可视化

1.先了解静态数据可视化,然后再学习动态数据可视化。

2.去echarts官网下载js文件,网址: https://www.echartsjs.com/zh/download.html点击在线定制

image.png


将下载的文件copy到static/js文件夹下,并记得改一下名称echarts.min.js

3. 构建web项目,如何能够加载页面效果,这里还需要在pom文件中添加一个maven依赖如下:

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>

记得重新导入maven依赖,并确认依赖是否导入。

4. 创建html文件

在templates文件夹下创建test.html文件:

5. 参照echarts官方文档

(1)引入echarts

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <!-- 引入 ECharts 文件 --> <script src="echarts.min.js"></script> </head> </html>

(2)绘制一个简单图表,可以去官网找个模板。

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<!-- 引入 ECharts 文件 -->
<script src="echarts.min.js"></script>
</head>
</html>


(2)绘制一个简单图表

<body>
<!-- 为ECharts准备一个具备大小(宽高)的Dom -->
<div id="main" style="width: 600px;height:400px;"></div>
<script type="text/javascript">
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title: {
text: 'ECharts 入门示例'
},
tooltip: {},
legend: {
data:['销量']
},
xAxis: {
data: ["衬衫","羊毛衫","雪纺衫","裤子","高跟鞋","袜子"]
},
yAxis: {},
series: [{
name: '销量',
type: 'bar',
data: [5, 20, 36, 10, 10, 20]
}]
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
</script>
</body>
6. 编写controller
@RequestMapping(value = "/first",method =RequestMethod.GET)
public ModelAndView firstDemo(){
return new ModelAndView("test");
}

7.访问测试:

http://localhost:8089/crn/first

image.png


稍微调整一下图表的位置:

搞定我们自己的静态页面:这是为了实现动态的展现做第一步的准备。

(1) 新创建一个html页面,将报表中对应的内容,改成我们自己的样式代码;

(2) 修改页面中的静态数据,使其能够成功展现;

4. 使用Echarts构建动态数据可视化

学习了Echarts的静态数据可视化之后,咱们再来学习动态数据的可视化。

搞定了静态页面,下面就可以开始实现动态数据的可视化了。

1. 后台准备数据

(0) 首先调整一下咱们的工程目录结构,勾选第二项Compact

image.png

使其更规范一些。

(1) 编写操作hbase的工具类;

添加依赖:

<repository>
<id>cloudera</id>
<url>https://repository.cloudera.com/artifactory/cloudera-repos/</url>
</repository>
<dependency>
<groupId>org.apache.hbase</groupId>
<artifactId>hbase-client</artifactId>
<version>${hbase.version}</version>
</dependency>

(2) 编写用于封装数据的实体类;

(3) 编写封装实体类数据的数据操作代码DAO;

(4)编写controller,调用dao将数据返回到前端页面;直接以List列表的方式返回;

a. 返回json数据的格式,所以还需要添加一个maven依赖:

b. 由于后端查询到的只是一个courseId,所以还需要进行一下转换。实际应用中id和name的对应关系肯定是配置在数据库中,咱这里为了简单就直接写成一个静态的代码块,写死在代码中。

(5)编写一个controller的方法,用于实现页面跳转;

(6)在页面中引入jQuery,异步调用ajax对后端数据进行请求:

通过上面的步骤,咱们可以实现统计每天实战课程的访问量,同理按照这个套路可以实现统计来自不同搜索引擎的课程访问量。

注意上面的流程中,已经包含了一个Spring boot集成使用echarts插件的完整流程了。在这里重新再梳理一下。

1. 使用idea构建一个maven管理的web项目;

2. 在pom文件中添加解析html的依赖;

3. 在templates文件夹中创建一个test.html;

4. 参考echarts官方说明流程:下载js,保存到resources目录下 > 在test.html中引入对应的js > 按照说明复制body中内容;

5. 编写controller代码,使用modeandview对应跳转访问html页面;测试是否能够成功访问;

6.测试通过后,进入echarts官网选择自己想要展示样式,将option代码复制;

7. 在后端controller中准备数据,在页面中动态访问实现数据的动态展示。

打包之后部署服务器:


使用阿里云DataV实现数据可视化

对于实现数据的可视化,不同的公司可能会有不同的方案。这里咱就为了适配不同的背景,再来学习一种很流行的可视化方案,那就是阿里云的DataV.

DataV功能说明:

1)点击量分省排名、运营商访问占比

通过IP解析到省份,城市,运营商 --> 这个在Spark SQL项目实战课程中有讲解

2) 浏览器访问占比、操作系统占比

通过解析userAgent -->这个在hadoop项目中有讲解

DataV实现数据可视化的流程:

资源准备:

(1) 一个公网能够访问的mysql数据库(DataV暂不支持hbase)

(2)DataV都是付费的,需要购买才能使用

流程:

1. 选择模板;调整文字时,都是带有样式操作界面的,可以很方便的进行调整;

2. 编写sql,查询数据库,实现动态展示。

对!流程就是这个简单!


相关实践学习
DataV Board用户界面概览
本实验带领用户熟悉DataV Board这款可视化产品的用户界面
阿里云实时数仓实战 - 项目介绍及架构设计
课程简介 1)学习搭建一个数据仓库的过程,理解数据在整个数仓架构的从采集、存储、计算、输出、展示的整个业务流程。 2)整个数仓体系完全搭建在阿里云架构上,理解并学会运用各个服务组件,了解各个组件之间如何配合联动。 3&nbsp;)前置知识要求 &nbsp; 课程大纲 第一章&nbsp;了解数据仓库概念 初步了解数据仓库是干什么的 第二章&nbsp;按照企业开发的标准去搭建一个数据仓库 数据仓库的需求是什么 架构 怎么选型怎么购买服务器 第三章&nbsp;数据生成模块 用户形成数据的一个准备 按照企业的标准,准备了十一张用户行为表 方便使用 第四章&nbsp;采集模块的搭建 购买阿里云服务器 安装 JDK 安装 Flume 第五章&nbsp;用户行为数据仓库 严格按照企业的标准开发 第六章&nbsp;搭建业务数仓理论基础和对表的分类同步 第七章&nbsp;业务数仓的搭建&nbsp; 业务行为数仓效果图&nbsp;&nbsp;
目录
相关文章
|
3月前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
66 4
|
3月前
|
Java API 数据库
如何使用Spring Boot构建RESTful API,以在线图书管理系统为例
【10月更文挑战第9天】本文介绍了如何使用Spring Boot构建RESTful API,以在线图书管理系统为例,从项目搭建、实体类定义、数据访问层创建、业务逻辑处理到RESTful API的实现,详细展示了每个步骤。通过Spring Boot的简洁配置和强大功能,开发者可以高效地开发出功能完备、易于维护的Web应用。
99 3
|
4天前
|
监控 Java API
【潜意识Java】使用SpringBoot构建高效的RESTfulAPI
本文介绍了使用Spring Boot构建RESTful API的完整流程,涵盖从项目创建到API测试的各个步骤。
21 1
|
2月前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。首先,创建并配置 Spring Boot 项目,实现后端 API;然后,使用 Ant Design Pro Vue 创建前端项目,配置动态路由和菜单。通过具体案例,展示了如何快速搭建高效、易维护的项目框架。
149 62
|
1月前
|
负载均衡 Java 开发者
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
176 5
|
2月前
|
消息中间件 Java Kafka
Spring Boot 与 Apache Kafka 集成详解:构建高效消息驱动应用
Spring Boot 与 Apache Kafka 集成详解:构建高效消息驱动应用
75 1
|
2月前
|
Java
SpringBoot构建Bean(RedisConfig + RestTemplateConfig)
SpringBoot构建Bean(RedisConfig + RestTemplateConfig)
54 2
|
2月前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,帮助开发者提高开发效率和应用的可维护性。
186 2
|
3月前
|
自然语言处理 Java API
Spring Boot 接入大模型实战:通义千问赋能智能应用快速构建
【10月更文挑战第23天】在人工智能(AI)技术飞速发展的今天,大模型如通义千问(阿里云推出的生成式对话引擎)等已成为推动智能应用创新的重要力量。然而,对于许多开发者而言,如何高效、便捷地接入这些大模型并构建出功能丰富的智能应用仍是一个挑战。
507 6
|
3月前
|
文字识别 安全 Java
SpringBoot3.x和OCR构建车牌识别系统
本文介绍了一个基于Java SpringBoot3.x框架的车牌识别系统,详细阐述了系统的设计目标、需求分析及其实现过程。利用Tesseract OCR库和OpenCV库,实现了车牌图片的识别与处理,确保系统的高准确性和稳定性。文中还提供了具体的代码示例,展示了如何构建和优化车牌识别服务,以及如何处理特殊和异常车牌。通过实际应用案例,帮助读者理解和应用这一解决方案。