JAVA 实践项目 --- 树莓派信息自动化采集后入库项目 (三)

本贴最后更新于 2474 天前,其中的信息可能已经渤澥桑田

项目源代码可访问我的 github:https://github.com/Spacider/Gather-and-store
如果觉得好的话请给个 star 哦~

开发 IDE: IDEA 2018.03 JDK 1.8
开发环境: macOS 10.13.6 (如 windows 请对项目中部分路径进行改写)
数据库: Oracle 11g


第二阶段:数据的采集和写入日志文件

在 JAVA 实践项目---树莓派信息自动化采集后入库项目(二) 中我们从模拟的树莓派服务器上得到了我们需要采集的数据,接下来我们要干的事儿就是把得到的 XML 继续解析,等到相应的数据把其写入一个文件中!文件内容如下图所示:
imagepng


话不多说,开始编写代码:

  1. 在我们的 SAXReaderHelper 类中编写方法 InLogFile:将获取到数据写入到日志文件中。
public static void InLogFile(String str,String SensorAddress,String counter){ }

它由 3 个参数,分别是我们读取的 XML 文件(通过流实际上使用的是 String 来接收),由于 SensorAddresscounter 参数返回的 XML 文件中没有这两个参数,所以我们通过传参的方式把这两个参数传入!

这里我们又用到了 dom4j 技术对其进行解析:

// 把客户端传过来的 xml 转化为字符串存储 String TotalStr = str.toString(); byte[] TotalBytes = TotalStr.getBytes(); // dom4j 构建对象内填入一个 byte 类型的数组 bais = new ByteArrayInputStream(TotalBytes); SAXReader reader = new SAXReader(); Document document = null;

通过对象流的方式直接交给 dom4j:

try { document = reader.read(bais,"utf-8"); }

有了 document 对象以后我们就可以解析了,接下来我们用一个 StringBuilder 来对字符串进行拼接,拼接成上图我们讲过的样子。最后加上 "\r\n",这样最后写入文件的时候每一条数据会换行。

// 获取根节点 Element Message = document.getRootElement(); StringBuilder sb = new StringBuilder(); // 拼接字符串 sb.append(Message.element("SrcID").getText()+"|"); sb.append(Message.element("DstID").getText()+"|"); sb.append(Message.element("DevID").getText()+"|"); sb.append(SensorAddress+"|"); sb.append(counter+"|"); sb.append(Message.element("Cmd").getText()+"|"); sb.append(Message.element("Data").getText()+"|"); sb.append(Message.element("Status").getText()+"|"); sb.append(new Timestamp(System.currentTimeMillis())); sb.append("\r\n");

得到拼接好数据的字符串以后我们要做的就是写入文件了,这里用到了文件输出流,最后记得 flush 哦!刷一下内容才会进去
注意:请在 src 下先创建 radwtmp 文件,这里的 "/Users/wjh/Desktop/FirstProject/src/radwtmp" 路径为我电脑上路径,请改成你的路径!

File file = new File("/Users/wjh/Desktop/FirstProject/src/radwtmp"); if (!file.exists()){ file.createNewFile(); } fos = new FileOutputStream(file,true); fos.write(sb.toString().getBytes()); fos.flush();
  1. 封装好方法以后我们就可以调用它了,在 ClientReceiveHelperClientGetXml 方法最后加入这么一行:
// 根据 XML 文件解析,并将其写入文件中 SAXReaderHelper.InLogFile(sb.toString(), SensorAddress, counter + "");
  1. 编写客户端主程序:
    DataClient(温度湿度客户端),GuangClient(树莓派光照客户端),CarbonDioxideClient(二氧化碳客户端):
    传入 SensorAddress 为传感器 ID,16 表示温度湿度传感器,256 表示光照传感器,1280 表示二氧化碳传感器
public static void DataGetObj(){ ClientReceiveHelper.ClientGetXml("16",1); }
public static void guangGetObj(){ ClientReceiveHelper.ClientGetXml("256",1); }
public static void CarbonDioxideGetObj(){ ClientReceiveHelper.ClientGetXml("1280",1); }
  1. 为了方便操作,我们设立一个定时器,编写一个定时器类:
public final class TimerRunClient { public static void runClientMain() { // 构建定时器 Timer timer = new Timer(false); /** * 第一个参数表示定时器执行的函数,第二个参数表示第一次定时器生效的时间,第三个参数表示每隔多长事件调用第一个参数所指向的方法 * 第二个参数和第三个参数单位是毫秒 */ timer.schedule(new TimerTask() { @Override public void run() { // 定时器调用的代码 DataClient.DataGetObj(); GuangClient.guangGetObj(); CarbonDioxideClient.CarbonDioxideGetObj(); } }, 0, 5000); } public static void main(String[] args) { runClientMain(); } }
  1. 运行定时器类(TimerRunClient)和树莓派系统数据模拟类(DataServer),看到 radwtmp 类中数据如下图所示即为成功!
    imagepng

本文中为代码详解,可能与源代码不一定相同,可以查看我的 github:https://github.com/Spacider/Gather-and-store 查看源代码与你的代码进行比对!如果觉得我写的好的话请给一个 star 哦!

  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3203 引用 • 8217 回帖 • 1 关注
  • 实践项目
    6 引用

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • 服务

    提供一个服务绝不仅仅是简单的把硬件和软件累加在一起,它包括了服务的可靠性、服务的标准化、以及对服务的监控、维护、技术支持等。

    41 引用 • 24 回帖 • 1 关注
  • RYMCU

    RYMCU 致力于打造一个即严谨又活泼、专业又不失有趣,为数百万人服务的开源嵌入式知识学习交流平台。

    4 引用 • 6 回帖 • 62 关注
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    730 引用 • 1284 回帖
  • Google

    Google(Google Inc.,NASDAQ:GOOG)是一家美国上市公司(公有股份公司),于 1998 年 9 月 7 日以私有股份公司的形式创立,设计并管理一个互联网搜索引擎。Google 公司的总部称作“Googleplex”,它位于加利福尼亚山景城。Google 目前被公认为是全球规模最大的搜索引擎,它提供了简单易用的免费服务。不作恶(Don't be evil)是谷歌公司的一项非正式的公司口号。

    49 引用 • 192 回帖
  • AWS
    11 引用 • 28 回帖 • 6 关注
  • Hibernate

    Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。

    39 引用 • 103 回帖 • 726 关注
  • 印象笔记
    3 引用 • 16 回帖
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    292 引用 • 4495 回帖 • 664 关注
  • 安装

    你若安好,便是晴天。

    132 引用 • 1184 回帖 • 2 关注
  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖 • 4 关注
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖 • 5 关注
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    694 引用 • 537 回帖 • 1 关注
  • CSDN

    CSDN (Chinese Software Developer Network) 创立于 1999 年,是中国的 IT 社区和服务平台,为中国的软件开发者和 IT 从业者提供知识传播、职业发展、软件开发等全生命周期服务,满足他们在职业发展中学习及共享知识和信息、建立职业发展社交圈、通过软件开发实现技术商业化等刚性需求。

    14 引用 • 155 回帖
  • 音乐

    你听到信仰的声音了么?

    62 引用 • 512 回帖
  • H2

    H2 是一个开源的嵌入式数据库引擎,采用 Java 语言编写,不受平台的限制,同时 H2 提供了一个十分方便的 web 控制台用于操作和管理数据库内容。H2 还提供兼容模式,可以兼容一些主流的数据库,因此采用 H2 作为开发期的数据库非常方便。

    11 引用 • 54 回帖 • 672 关注
  • 服务器

    服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。

    125 引用 • 585 回帖
  • Spark

    Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。

    74 引用 • 46 回帖 • 564 关注
  • 阿里巴巴

    阿里巴巴网络技术有限公司(简称:阿里巴巴集团)是以曾担任英语教师的马云为首的 18 人,于 1999 年在中国杭州创立,他们相信互联网能够创造公平的竞争环境,让小企业通过创新与科技扩展业务,并在参与国内或全球市场竞争时处于更有利的位置。

    43 引用 • 221 回帖 • 46 关注
  • 分享

    有什么新发现就分享给大家吧!

    248 引用 • 1795 回帖
  • 电影

    这是一个不能说的秘密。

    123 引用 • 608 回帖
  • 区块链

    区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。所谓共识机制是区块链系统中实现不同节点之间建立信任、获取权益的数学算法 。

    92 引用 • 752 回帖
  • jQuery

    jQuery 是一套跨浏览器的 JavaScript 库,强化 HTML 与 JavaScript 之间的操作。由 John Resig 在 2006 年 1 月的 BarCamp NYC 上释出第一个版本。全球约有 28% 的网站使用 jQuery,是非常受欢迎的 JavaScript 库。

    63 引用 • 134 回帖 • 736 关注
  • 大数据

    大数据(big data)是指无法在一定时间范围内用常规软件工具进行捕捉、管理和处理的数据集合,是需要新处理模式才能具有更强的决策力、洞察发现力和流程优化能力的海量、高增长率和多样化的信息资产。

    89 引用 • 113 回帖
  • PWA

    PWA(Progressive Web App)是 Google 在 2015 年提出、2016 年 6 月开始推广的项目。它结合了一系列现代 Web 技术,在网页应用中实现和原生应用相近的用户体验。

    14 引用 • 69 回帖 • 185 关注
  • JSON

    JSON (JavaScript Object Notation)是一种轻量级的数据交换格式。易于人类阅读和编写。同时也易于机器解析和生成。

    53 引用 • 190 回帖
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    54 引用 • 37 回帖 • 2 关注
  • MyBatis

    MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

    173 引用 • 414 回帖 • 360 关注