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




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



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






java可视化窗口链接 java web数据可视化_可视化


java可视化窗口链接 java web数据可视化_java_02


java可视化窗口链接 java web数据可视化_vue_03


java可视化窗口链接 java web数据可视化_java_04


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


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


java可视化窗口链接 java web数据可视化_java可视化窗口链接_05


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


java可视化窗口链接 java web数据可视化_spring_06


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


创建一个Controller:


java可视化窗口链接 java web数据可视化_java_07


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,鼠标点击右键:


启动日志:


java可视化窗口链接 java web数据可视化_可视化_08


java可视化窗口链接 java web数据可视化_vue_09


前端访问测试:


http://localhost:8080/hello


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


java可视化窗口链接 java web数据可视化_可视化_10


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


再次进行访问测试:


http://localhost:8089/crn/hello

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


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


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


java可视化窗口链接 java web数据可视化_java_11


将下载的文件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官方文档http://echarts.baidu.com/tutorial.html#5%20%E5%88%86%E9%92%9F%E4%B8%8A%E6%89%8B%20ECharts


(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


java可视化窗口链接 java web数据可视化_可视化_12


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


<div id="main" style="width: 600px;height:400px;position: absolute;top: 50%;left: 50%;margin-top: -200px;margin-left: -300px"></div>


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


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


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


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


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


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


1. 后台准备数据


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


java可视化窗口链接 java web数据可视化_java_13


使其更规范一些。


(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,查询数据库,实现动态展示。


对!流程就是这个简单!