热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java监听ipv6的udp_对于IPv6网络UDP数据包的接收解析与存储方法与流程

本发明涉及一种数据包接收与存储方法。背景技术:Java是一门面向对象编程语言,不仅吸收了C语言的各种优点,还摒弃了C里难以理解的多继承、指

d1991bb84f0f3e7808ab0f1649cb8320.gif

本发明涉及一种数据包接收与存储方法。

背景技术:

Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征。Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。Java具有简单性、面向对象、分布式、健壮性、安全性、平台独立与可移植性、多线程、动态性等特点。Java可以编写桌面应用程序、Web应用程序、分布式系统和嵌入式系统应用程序等。

由于IPv6最大的问题在于网络地址资源有限,严重制约了互联网的应用和发展。IPv6的使用,不仅能解决网络地址资源数量的问题,而且也解决了多种接入设备连入互联网的障碍,IPv6协议主要定义了三种地址类型:单播地址(Unicast Address)、组播地址(Multicast Address)和任播地址(Anycast Address)。与原来在IPv4地址相比,新增了“任播地址”类型,取消了原来IPv4地址中的广播地址,因为在IPv6中的广播功能是通过组播来完成的。而IPV6下一代互联网主角,必将应用到生活中的方方面面,其与物联网的结合势在必行。IPV6无论是接入地址亦或是寻址等问题都能凭借其技术优势顺利解决,尤其在IPV6成为国家战略后,在国家全力支撑的背景下,将物联网与IPV6相结合必然是大势所趋,而且符合未来技术发展趋势。

随着物联网的大力发展,接入节点的要求都是低功耗,低传输速率的,这时TCP传输协议并不适用,而UDP传输协议便成了很好的替代品,UDP传输协议是一种不可靠的网络协议,在低功耗、低传输速率、低开销下UDP协议会变得非常有用。因为UDP具有TCP所望尘莫及的速度优势。虽然TCP协议中植入了各种安全保障功能,但是在实际执行的过程中会占用大量的系统开销,无疑使速度受到严重的影响。反观UDP由于排除了信息可靠传递机制,将安全和排序等功能移交给上层应用来完成,极大降低了执行时间,使速度得到了保证。

随着物联网行业的兴起,在数据传输方面更多的要求是低功耗、低传输速率、低开销下、低内存。传统的TCP传输协议并不适用于物联网底层感知数据的传输,而UDP传输协议的控制选项较少,在数据传输过程中延迟小、数据传输效率高,适合对可靠性要求不高的应用程序,它不属于连接型协议,因而具有资源消耗小,处理速度快的优点,所以通常音频、视频和普通数据在传送时使用UDP较多,因为它们即使偶尔丢失一两个数据包,也不会对接收结果产生太大影响,非常适合物联网感知数据的传送,因此服务器端UDP数据包的接收必不可少。

技术实现要素:

本发明提供一种基于Java的对于IPv6网络UDP数据包的接收解析与存储方法,用以接收UDP数据包并解析其中有用信息,将信息存储至数据库以便进行数据分析。技术方案如下:

一种对于IPv6网络UDP数据包的接收解析与存储方法,在接收UDP数据包的过程中,使用Java自有的DatagramSocket、InetAddress和Runnable类,步骤如下:创建一个包含main函数的Kernel类作为程序运行的开始,在该类中创建数据下载的Upload的线程并且启动该线程,此时数据接收开始;程序跳转到Upload中执行,该类继承Runnable类并对其中的run()方法进行重写,之后程序跳转到Receive类中,该类是接收UDP数据包的具体执行类;将解析后的数据通过InsertMySQL类中的addDataToTemHumTable()函数完成数据的存储。

本发明的有益效果如下:

1.本发明提出一种基于Java的对于IPv6网络UDP数据包的接收解析与存储,为开发人员提供了一种数据接收方式,有益于物联网的发展。

2.通过使用Java语言eclipse开发工具监听端口完成对UDP数据包的接收并解析后存储。由于Java语言使用的普遍性,方便开发人员的深入开发。

附图说明

图1系统运行流程图

具体实施方式

本发明在接收UDP数据包的过程中,使用了Java自有的DatagramSocket、InetAddress和Runnable类。具体流程是:首先创建一个包含main函数的Kernel类作为程序运行的开始,在该类中创建数据下载的Upload的线程并且启动该线程,此时数据接收开始。然后程序跳转到Upload中执行,该类继承Runnable类并对其中的run()方法进行重写,之后程序跳转到Receive类中,该类是接收UDP数据包的具体执行类。最后将解析后的数据通过InsertMySQL类中的addDataToTemHumTable()函数完成数据的存储。

具体实施方式

本发明在接收UDP数据包的过程中,使用了Java自有的DatagramSocket、InetAddress和Runnable类。具体流程是:首先创建一个包含main函数的Kernel类作为程序运行的开始,在该类中创建数据下载的Upload的线程并且启动该线程,此时数据接收开始。然后程序跳转到Upload中执行,该类继承Runnable类并对其中的run()方法进行重写,之后程序跳转到Receive类中,该类是接收UDP数据包的具体执行类。最后将解析后的数据通过InsertMySQL类中的addDataToTemHumTable()函数完成数据的存储。

1线程的创建

该类较为简单,只有一个main函数,作为整个项目的开始,函数中创建一个数据接收的线程并启动该线程,之后程序跳转到Upload类中运行。

2数据接收的启动

该类也较为简单,继承Java自带的Runnable父类并重写run()方法,此时启动数据接收模块,程序跳转到并使用try,catch结构,当数据接收启动失败是抛出异常。

3数据接收与解析

第一步通过DatagramSocket socket=new DatagramSocket(port,ip6address)创建接收套接字对象,并与所监听的端口号和本机ipv6地址保持一致。第二步通过DatagramPacket packet=new DatagramPacket(buf,buf.length)创建接收数据包存储在buf中,buf为数据接收的缓存数组。第三步通过SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss")设置日期,将接收到数据的时间日期设为yyyy-MM-dd HH:mm:ss格式。第四步通过Split函数将数据包中的接收到的数据按照空格进行切割,并存储到变量date中,之后将切割后的每一部分分别存储到相应的变量中。第五步创建list数组,将每个变量添加到该list中,然后调用addDataToTemHumTable(list)函数将list中的数据添加到数据库中,此时程序跳转到InsertMySQL中执行。至此数据的接收与解析完成。

4解析后数据的存储

该类的主要功能是将数据向数据库中存储,主要包括3个函数,获取数据库的连接getConn()、关闭数据库连接closeAll()和向数据库中添加数据addDataToTemHumTable()。上一步中调用的就是addDataToTemHumTable()函数,在该函数中首先获取数据库连接,将上一步中传来的list列表通过sql语句"INSERT INTO TemHumSensor(receiveTime,Tem,Hum,sensorIP,sensorPort)VALUES(?,?,?,?,?)"写入到数据库中。至此完成从端口接收数据,经过解析后存储到数据库中以方便分析使用。

本发明适用于物联网系统中IPv6网络UDP数据包的接收。随着物联网行业的兴起,在数据传输方面更多的要求是低功耗、低传输速率、低开销下、低内存,UDP传输协议将普遍应用于物联网行业,因此对于UDP数据包的接收处理会大量使用,而本发明提出一种基于Java的对于IPv6网络UDP数据包的接收解析与存储,为开发人员提供了一种数据接收方式,有益于物联网的发展。



推荐阅读
  • 在《Linux高性能服务器编程》一书中,第3.2节深入探讨了TCP报头的结构与功能。TCP报头是每个TCP数据段中不可或缺的部分,它不仅包含了源端口和目的端口的信息,还负责管理TCP连接的状态和控制。本节内容详尽地解析了TCP报头的各项字段及其作用,为读者提供了深入理解TCP协议的基础。 ... [详细]
  • 本文详细介绍如何使用Netzob工具逆向未知通信协议,涵盖从基本安装到高级模糊测试的全过程。通过实例演示,帮助读者掌握Netzob的核心功能。 ... [详细]
  • 小王详解:内部网络中最易理解的NAT原理剖析,挑战你的认知极限
    小王详解:内部网络中最易理解的NAT原理剖析,挑战你的认知极限 ... [详细]
  • centos 7.0 lnmp成功安装过程(很乱)
    下载nginx[rootlocalhostsrc]#wgethttp:nginx.orgdownloadnginx-1.7.9.tar.gz--2015-01-2412:55:2 ... [详细]
  • Linux 防火墙与端口管理必备命令
    在使用 Linux 系统进行服务部署和问题排查时,防火墙和端口管理是不可或缺的操作。本文将详细介绍如何查看防火墙状态、端口占用情况,以及如何开放和关闭端口,帮助初学者更好地掌握这些技能。 ... [详细]
  • 本文整理了一份基础的嵌入式Linux工程师笔试题,涵盖填空题、编程题和简答题,旨在帮助考生更好地准备考试。 ... [详细]
  • 深入理解Redis中的字典实现
    本文详细介绍了Redis中字典的实现机制,包括其底层数据结构、哈希表与哈希节点的关系、元素添加方法及rehash操作的具体流程。 ... [详细]
  • 小程序的授权和登陆
    小程序的授权和登陆 ... [详细]
  • 兆芯X86 CPU架构的演进与现状(国产CPU系列)
    本文详细介绍了兆芯X86 CPU架构的发展历程,从公司成立背景到关键技术授权,再到具体芯片架构的演进,全面解析了兆芯在国产CPU领域的贡献与挑战。 ... [详细]
  • 本文介绍了Spring 2.0引入的TaskExecutor接口及其多种实现,包括同步和异步执行任务的方式。文章详细解释了如何在Spring应用中配置和使用这些线程池实现,以提高应用的性能和可管理性。 ... [详细]
  • 本文详细介绍了Java代码分层的基本概念和常见分层模式,特别是MVC模式。同时探讨了不同项目需求下的分层策略,帮助读者更好地理解和应用Java分层思想。 ... [详细]
  • JUC(三):深入解析AQS
    本文详细介绍了Java并发工具包中的核心类AQS(AbstractQueuedSynchronizer),包括其基本概念、数据结构、源码分析及核心方法的实现。 ... [详细]
  • 在开发过程中,我最初也依赖于功能全面但操作繁琐的集成开发环境(IDE),如Borland Delphi 和 Microsoft Visual Studio。然而,随着对高效开发的追求,我逐渐转向了更加轻量级和灵活的工具组合。通过 CLIfe,我构建了一个高度定制化的开发环境,不仅提高了代码编写效率,还简化了项目管理流程。这一配置结合了多种强大的命令行工具和插件,使我在日常开发中能够更加得心应手。 ... [详细]
  • 本文深入解析了Java 8并发编程中的`AtomicInteger`类,详细探讨了其源码实现和应用场景。`AtomicInteger`通过硬件级别的原子操作,确保了整型变量在多线程环境下的安全性和高效性,避免了传统加锁方式带来的性能开销。文章不仅剖析了`AtomicInteger`的内部机制,还结合实际案例展示了其在并发编程中的优势和使用技巧。 ... [详细]
  • Java测试服务器调试指南详细介绍了如何进行远程调试,并深入解析了Java Xdebug参数的使用方法。本文首先概述了Java内置的调试功能,重点介绍了JDB这一类似于GDB的强大调试工具。通过实例演示,读者可以掌握在测试环境中高效调试Java应用程序的技巧,包括配置远程调试环境和优化调试参数,以提高开发效率和代码质量。 ... [详细]
author-avatar
青岛二三事-丶儿
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有