《计算机网络简易速速上手小册》第9章:物联网(IoT)与网络技术(2024 最新版)

在这里插入图片描述

文章目录

  • 9.1 IoT 架构与通信协议 - 打造智能世界的秘诀
    • 9.1.1 基础知识
    • 9.1.2 重点案例:使用 Python 和 MQTT 实现智能家居照明系统
      • 准备工作
      • Python 脚本示例
        • 发布者(灯光控制)
        • 订阅者(灯光状态接收):
    • 9.1.3 拓展案例1:使用 Python 和 CoAP 实现温度监控
      • 准备工作
      • Python 脚本示例
        • CoAP 客户端
        • CoAP 服务器
    • 9.1.4 拓展案例2:利用 Python 和 HTTP/HTTPS 协议集成天气服务
  • 9.2 IoT 安全挑战 - 导航在网络安全的海洋
    • 9.2.1 基础知识
    • 9.2.2 重点案例:使用 Python 实现 MQTT 消息加密
      • 准备工作
      • Python 脚本示例
        • 加密发布者:
        • 解密订阅者:
    • 9.2.3 拓展案例1:使用 Python 实现设备身份验证
      • Python 脚本示例:使用 SSL/TLS 的 MQTT 客户端
    • 9.2.4 拓展案例2:自动化固件更新
      • Python 脚本示例
        • 下载并验证固件包
  • 9.3 IoT 案例研究 - 智能科技的实践场
    • 9.3.1 基础知识
    • 9.3.2 重点案例:智能农业监控系统
      • 准备工作
      • Python 脚本示例
        • 数据收集和传输:
        • 数据处理和决策:
    • 9.3.3 拓展案例1:智能家居安全系统
      • Python 脚本示例 - 数据发送端(模拟传感器)
    • 9.3.4 拓展案例2:远程健康监测系统
      • Python 脚本示例 - 数据发送端(模拟健康监测设备)

9.1 IoT 架构与通信协议 - 打造智能世界的秘诀

物联网(IoT)正在以其独特的方式改变我们的世界,从智能家居到工业自动化,IoT 设备的普及为日常生活和工作带来了前所未有的便利。要理解 IoT 的魔力,首先需要掌握其基础架构和通信协议。

9.1.1 基础知识

  • IoT 架构:通常分为三层:感知层(负责收集数据)、网络层(负责数据传输)和应用层(负责数据处理和展示)。这种分层架构确保了 IoT 系统的灵活性和可扩展性。
  • 通信协议:IoT 设备之间的有效通信依赖于各种协议,包括但不限于:
    • MQTT(消息队列遥测传输):轻量级的发布/订阅网络协议,适用于带宽受限环境。
    • CoAP(受限应用协议):专为小型物联网设备设计的协议,支持 RESTful API。
    • HTTP/HTTPS:虽然不如 MQTT 和 CoAP 轻量,但在互联网应用中广泛使用。

9.1.2 重点案例:使用 Python 和 MQTT 实现智能家居照明系统

在这个案例中,我们将使用 MQTT 协议和 Python 来构建一个简单的智能家居照明控制系统。

准备工作

  1. 安装 Paho-MQTT 客户端库:

    pip install paho-mqtt
    
  2. 准备一个 MQTT 代理/服务器地址(例如使用 Mosquitto 或云MQTT服务)。

Python 脚本示例

发布者(灯光控制)
import paho.mqtt.client as mqttmqtt_broker = "your_mqtt_broker_address"
topic = "home/lighting"def on_connect(client, userdata, flags, rc):print("Connected with result code "+str(rc))client = mqtt.Client()
client.on_connect = on_connectclient.connect(mqtt_broker, 1883, 60)
client.loop_start()# 发送开灯命令
client.publish(topic, "ON")
print("Light ON command sent.")# 关灯命令可通过发送 "OFF" 来实现
# client.publish(topic, "OFF")
订阅者(灯光状态接收):
import paho.mqtt.client as mqttmqtt_broker = "your_mqtt_broker_address"
topic = "home/lighting"def on_connect(client, userdata, flags, rc):print("Connected with result code "+str(rc))client.subscribe(topic)def on_message(client, userdata, msg):print(f"Lighting Control Message: {msg.payload.decode()}")client = mqtt.Client()
client.on_connect = on_connect
client.on_message = on_messageclient.connect(mqtt_broker, 1883, 60)
client.loop_forever()

9.1.3 拓展案例1:使用 Python 和 CoAP 实现温度监控

由于实现这个案例需要特定的 CoAP 库和环境配置,这里仅概述实现思路:使用 CoAP 协议和 Python,可以创建一个简易的温度监控系统,该系统定期从温度传感器读取数据,并通过 CoAP 发送到中央监控系统。

由于CoAP(受限应用协议)是专为物联网(IoT)设备设计的轻量级协议,它支持简单的请求/响应模型,类似于HTTP,但是针对低功耗和低带宽环境进行了优化。在Python中使用CoAP通常需要专门的库。一个常用的库是aiocoap,它是基于Python的异步I/O(asyncio)。

准备工作

首先,确保安装了aiocoap库。如果未安装,可以通过以下命令安装:

pip install aiocoap

Python 脚本示例

CoAP 客户端

以下是使用aiocoap库的CoAP客户端示例,用于发送请求到CoAP服务器并接收响应。这个例子假设你有一个运行CoAP服务的服务器,可以处理GET请求。

import asyncio
from aiocoap import *async def main():protocol = await Context.create_client_context()request = Message(code=GET, uri='coap://[服务器地址]/[资源路径]')try:response = await protocol.request(request).responseexcept Exception as e:print('Failed to fetch resource:')print(e)else:print('Result: %s\n%r'%(response.code, response.payload))if __name__ == "__main__":asyncio.get_event_loop().run_until_complete(main())

请将[服务器地址][资源路径]替换成实际的值。这个脚本将发送一个GET请求到指定的CoAP服务器和资源路径,然后输出响应的状态码和负载。

CoAP 服务器

为了完整性,这里也提供一个简单的CoAP服务器示例,它可以响应上述客户端的请求:

import asyncio
from aiocoap import *class CoAPServerResource(Resource):async def render_get(self, request):return Message(payload=b"Hello, CoAP!")async def main():# 创建CoAP服务器root = ResourceSite()root.add_resource(['your', 'resource', 'path'], CoAPServerResource())await Context.create_server_context(root)if __name__ == "__main__":asyncio.get_event_loop().run_until_complete(main())

这个服务器脚本创建了一个简单的CoAP服务器,它在特定的资源路径上监听GET请求,并返回一个简单的文本响应。请将['your', 'resource', 'path']替换为你希望服务器监听的路径。

通过这个拓展案例1的CoAP客户端和服务器示例,我们可以看到如何在Python中使用aiocoap库来实现CoAP通信,这对于开发物联网应用尤其重要,特别是在资源受限的环境中。

9.1.4 拓展案例2:利用 Python 和 HTTP/HTTPS 协议集成天气服务

通过 HTTP/HTTPS 协议,可以轻松地将第三方天气服务(如 OpenWeatherMap)集成到 IoT 应用中,为用户提供实时天气信息。

import requestsdef get_weather(api_key, city):url = f"http://api.openweathermap.org/data/2.5/weather?q={city}&appid={api_key}"response = requests.get(url)weather_data = response.json()print(weather_data)api_key = "your_api_key"
city = "Beijing"
get_weather(api_key, city)

通过这些案例,我们可以看到 IoT 架构和通信协议在实现智能设备互联和数据交互中的重要作用。无论是通过 MQTT 实现的轻量级消息传递,还是通过 CoAP 和 HTTP/HTTPS 实现的资源访问,Python 都为 IoT 设备提供了强大的编程支持,使得构建复杂的 IoT 应用变得简单和可行。

在这里插入图片描述


9.2 IoT 安全挑战 - 导航在网络安全的海洋

物联网(IoT)带来了无限的可能性,但同时也引入了许多安全挑战。从智能家居设备到工业传感器,IoT 设备往往是安全攻击的目标,因为它们可能缺乏足够的安全防护措施。让我们深入了解 IoT 安全的基础知识,并通过一些案例学习如何使用 Python 来增强 IoT 设备的安全性。

9.2.1 基础知识

  • 设备身份验证:确保只有授权的设备能够连接到 IoT 网络。
  • 数据加密:对传输和存储的数据进行加密,保护数据不被未授权访问或篡改。
  • 固件更新:定期更新设备固件,修补已知的安全漏洞。
  • 安全通信协议:使用安全的通信协议,如 TLS/SSL,来保护数据传输过程中的安全。
  • 访问控制:限制对设备和数据的访问,确保只有授权用户才能访问重要资源。

9.2.2 重点案例:使用 Python 实现 MQTT 消息加密

在这个案例中,我们将使用 Python 和 paho-mqtt 库来实现 MQTT 消息的加密,以保护 IoT 设备间的通信安全。

准备工作

  1. 安装 paho-mqttcryptography 库:

    pip install paho-mqtt cryptography
    

Python 脚本示例

加密发布者:
from cryptography.fernet import Fernet
import paho.mqtt.client as mqtt# 生成一个密钥
key = Fernet.generate_key()
cipher_suite = Fernet(key)mqtt_broker = "your_mqtt_broker_address"
topic = "secure/home/lighting"def on_connect(client, userdata, flags, rc):print(f"Connected with result code {rc}")client = mqtt.Client()
client.on_connect = on_connectclient.connect(mqtt_broker, 1883, 60)
client.loop_start()# 加密消息
message = cipher_suite.encrypt(b"Turn on the light")
client.publish(topic, message)
print("Encrypted message sent.")
解密订阅者:
from cryptography.fernet import Fernet
import paho.mqtt.client as mqttkey = b'your_generated_key_here'
cipher_suite = Fernet(key)mqtt_broker = "your_mqtt_broker_address"
topic = "secure/home/lighting"def on_connect(client, userdata, flags, rc):print(f"Connected with result code {rc}")client.subscribe(topic)def on_message(client, userdata, msg):decrypted_message = cipher_suite.decrypt(msg.payload)print(f"Decrypted message: {decrypted_message}")client = mqtt.Client()
client.on_connect = on_connect
client.on_message = on_messageclient.connect(mqtt_broker, 1883, 60)
client.loop_forever()

请将 "your_mqtt_broker_address" 替换为你的 MQTT 代理地址,并确保 "your_generated_key_here" 与发布者使用的密钥相同。

9.2.3 拓展案例1:使用 Python 实现设备身份验证

考虑到篇幅限制,这里简要介绍如何使用 Python 进行基于证书的设备身份验证的概念。在实际应用中,你可以使用 ssl 模块为 MQTT 客户端和服务器之间的连接添加 TLS 支持,从而实现加密通信和设备身份验证。

由于拓展案例提到的概念通常涉及特定环境或框架的复杂配置,直接实施可能超出简单脚本能够覆盖的范围。但我会尽力提供一些概念性的代码示例,以给出一个大概的实现方向。

Python 脚本示例:使用 SSL/TLS 的 MQTT 客户端

对于基于证书的设备身份验证,以下是一个概念性的 Python 示例,展示如何使用 ssl 模块为 MQTT 客户端添加 TLS 支持,实现设备的身份验证。

import paho.mqtt.client as mqtt
import sslmqtt_broker = "your_mqtt_broker_address"
port = 8883  # 通常用于MQTT over SSL的端口
ca_certs = "/path/to/ca_certificate.pem"  # CA证书路径
certfile = "/path/to/client_certificate.pem"  # 客户端证书路径
keyfile = "/path/to/client_key.pem"  # 客户端私钥路径def on_connect(client, userdata, flags, rc):if rc == 0:print("Connected successfully.")else:print(f"Connect failed with error code {rc}")client = mqtt.Client()
client.tls_set(ca_certs, certfile=certfile, keyfile=keyfile, cert_reqs=ssl.CERT_REQUIRED, tls_version=ssl.PROTOCOL_TLSv1_2)
client.tls_insecure_set(False)  # 在生产环境中应设置为False
client.on_connect = on_connectclient.connect(mqtt_broker, port, 60)
client.loop_forever()

请替换 mqtt_brokerca_certscertfilekeyfile 的值为你的实际配置。这个脚本创建了一个使用 TLS 加密的 MQTT 客户端,并通过 CA 证书验证 MQTT 服务器的身份,同时使用客户端证书进行自身的身份验证。

9.2.4 拓展案例2:自动化固件更新

通过 Python 脚本自动化固件更新流程,可以有效地减少设备受到已知安全漏洞攻击的风险。这通常涉及到从安全的服务器下载签名的固件更新包,并在设备上进行验证和安装。

Python 脚本示例

由于涉及到设备特定的操作,这里只简单提供代码示例。自动化固件更新通常涉及到从服务器下载固件包、验证签名以及在设备上安装固件的过程。以下是一个概念性的 Python 脚本示例,展示了如何下载并验证固件包的数字签名。

下载并验证固件包
import requests
from cryptography.hazmat.backends import default_backend
from cryptography.hazmat.primitives import serialization
from cryptography.hazmat.primitives import hashes
from cryptography.hazmat.primitives.asymmetric import paddingfirmware_url = "https://example.com/firmware/update.bin"
public_key_url = "https://example.com/public_key.pem"
signature_url = "https://example.com/firmware/signature.sig"# 下载固件包
firmware_response = requests.get(firmware_url)
firmware_data = firmware_response.content# 下载公钥
public_key_response = requests.get(public_key_url)
public_key = serialization.load_pem_public_key(public_key_response.content,backend=default_backend()
)# 下载签名
signature_response = requests.get(signature_url)
signature = signature_response.content# 验证签名
try:public_key.verify(signature,firmware_data,padding.PSS(mgf=padding.MGF1(hashes.SHA256()),salt_length=padding.PSS.MAX_LENGTH),hashes.SHA256())print("Firmware signature is valid.")
except Exception as e:print("Firmware signature is invalid.", e)

这个脚本首先从指定的 URL 下载固件包、公钥和签名文件。然后,使用下载的公钥验证固件包的签名。这确保了固件包的真实性和完整性,是自动化固件更新过程中的关键安全步骤。

以上示例仅提供了概念性的代码框架,具体实现将需要根据实际的环境和需求进行调整。

通过这些案例,我们可以看到,增强 IoT 设备的安全性需要综合考虑多个方面,包括加密通信、设备身份验证和及时的固件更新等。使用 Python 为 IoT 设备和应用实现安全措施,不仅可以保护数据的安全和隐私,还可以增强整个 IoT 系统的可靠性。

在这里插入图片描述


9.3 IoT 案例研究 - 智能科技的实践场

物联网(IoT)的兴起,为各行各业带来了革命性的变化。通过将传感器、设备和人连接起来,IoT 解锁了大量的新应用场景,从而极大地提高了效率、安全性和用户体验。让我们深入探讨几个具体的 IoT 应用案例,了解它们是如何在现实世界中发挥作用的。

9.3.1 基础知识

  • 数据收集:IoT 设备通过传感器收集各种数据,如温度、湿度、位置等。
  • 数据通信:收集的数据通过网络传输到服务器或云平台,使用各种通信协议如 MQTT、CoAP 等。
  • 数据处理和分析:通过软件应用对数据进行处理和分析,提取有价值的信息。
  • 智能决策和控制:基于分析结果,自动或人工做出决策,并控制 IoT 设备执行特定任务。

9.3.2 重点案例:智能农业监控系统

在这个案例中,我们将构建一个简单的智能农业监控系统,使用 Python 收集温度和湿度数据,并基于这些数据自动控制灌溉系统。

准备工作

  1. 安装必要的 Python 库:paho-mqtt用于 MQTT 通信。

    pip install paho-mqtt
    

Python 脚本示例

数据收集和传输:

假设温度和湿度传感器数据通过 MQTT 发布:

import paho.mqtt.publish as publishmqtt_broker = "your_mqtt_broker_address"
topic = "farm/sensor/data"# 假设的温度和湿度值
temperature = 25.5  # 摄氏度
humidity = 60  # 百分比# 发布传感器数据
publish.single(topic, f"temperature:{temperature},humidity:{humidity}", hostname=mqtt_broker)
print("Sensor data published.")
数据处理和决策:

这部分通常在服务器或云端进行,这里简化为一个接收 MQTT 消息并做出决策的脚本:

import paho.mqtt.client as mqttdef on_connect(client, userdata, flags, rc):print("Connected with result code "+str(rc))client.subscribe("farm/sensor/data")def on_message(client, userdata, msg):print(f"Received data: {msg.payload.decode()}")# 简化的决策逻辑:如果温度高于24度且湿度低于65%,则启动灌溉temperature, humidity = map(float, msg.payload.decode().split(',')[0].split(':')[1]), float(msg.payload.decode().split(',')[1].split(':')[1])if temperature > 24 and humidity < 65:print("Activating irrigation system...")# 这里可以添加控制灌溉系统的代码client = mqtt.Client()
client.on_connect = on_connect
client.on_message = on_messageclient.connect("your_mqtt_broker_address", 1883, 60)
client.loop_forever()

9.3.3 拓展案例1:智能家居安全系统

利用 IoT 设备和传感器监测家庭安全,如门窗状态、烟雾报警等,并通过手机应用实时接收通知。

由于直接实现完整的拓展案例可能需要复杂的设备配置和较长的代码,我将提供概念性的 Python 代码示例,展示如何使用 Python 进行数据收集、发送和简单处理,以概括拓展案例的实现思路。

假设我们有一个智能家居安全系统,它包括门窗传感器和烟雾探测器。当门窗被非法打开或检测到烟雾时,系统将通过 MQTT 协议发送警报信息。

Python 脚本示例 - 数据发送端(模拟传感器)

import paho.mqtt.publish as publishmqtt_broker = "your_mqtt_broker_address"
topics = ["home/security/door", "home/security/smoke"]# 模拟传感器触发
door_open = True
smoke_detected = Falseif door_open:publish.single(topics[0], "Door opened", hostname=mqtt_broker)print("Door opened alert sent.")if smoke_detected:publish.single(topics[1], "Smoke detected", hostname=mqtt_broker)print("Smoke alert sent.")

9.3.4 拓展案例2:远程健康监测系统

通过穿戴设备收集健康数据(如心率、血压等),并将数据发送到医疗中心,医生可以实时监控患者的健康状况。

假设我们有一个远程健康监测系统,它包括心率和血压监测。这些数据将定期收集并发送到医疗中心进行监控。

Python 脚本示例 - 数据发送端(模拟健康监测设备)

import paho.mqtt.publish as publishmqtt_broker = "your_mqtt_broker_address"
topic = "health/monitoring"# 模拟监测数据
heart_rate = 75  # bpm
blood_pressure = "120/80"  # 假设的血压值message = f"Heart Rate: {heart_rate}, Blood Pressure: {blood_pressure}"publish.single(topic, message, hostname=mqtt_broker)
print("Health data sent.")

在这两个拓展案例中,我们模拟了传感器/设备端通过 MQTT 协议发送数据的过程。在实际应用中,数据接收端(如智能家居的中央控制系统或医疗中心的服务器)将需要实现相应的 MQTT 客户端来订阅主题并处理收到的消息,如触发警报、通知医生等。

请注意,为了简化示例,这里没有展示数据接收和处理的代码。在实际部署时,你需要结合具体的业务逻辑和需求,设计和实现数据的接收、处理和响应机制。

由于篇幅限制,这里不提供拓展案例的具体代码实现。然而,实现这些案例的基本思路与主案例相似:收集数据、通过网络发送数据、在服务器或云端处理数据,并根据数据做出智能决策。使用 Python 和适当的通信协议,我们可以轻松地构建起这样一个系统的原型,无论是在智能农业、智能家居安全,还是远程健康监测方面。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/450210.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网络异常案例二_RST

IP冲突导致的内网服务器访问异常问题 问题现象&#xff0c;个人台式机某天访问内网服务器异常&#xff0c;反馈给运维同学。 运维同学答复正常&#xff0c;他本地可以访问&#xff0c;自己用笔记本验证也可以正常访问。 没有头绪&#xff0c;抓包分析&#xff0c;发现请求全部…

Facebook的数字合作愿景:创新与未来发展

随着科技的飞速发展&#xff0c;Facebook一直处于数字创新的前沿&#xff0c;致力于构建开放、智能、社交的数字社交体验。本文将深入探讨Facebook的数字合作愿景&#xff0c;探索其在创新与未来发展方面的雄心壮志。 引言 在当今数字化时代&#xff0c;社交媒体不仅是人们沟通…

C++内存管理详解

目录 一、C/C内存分布 2.C语言中动态内存管理方式&#xff1a;malloc/calloc/realloc/free 2.1malloc 2.2calloc 2.3realloc 2.4free 3.C内存管理方式 3.1new和malloc 3.2new和delete操作自定义类型 3.3operator new和operator delete 3.4new和delete的实现原理 3.4.1内置类型 …

使用 git 将本地文件上传到 gitee 远程仓库中,推送失败

项目场景&#xff1a; 背景&#xff1a; 使用 git 想要push 本地文件 到 另一个远程仓库&#xff0c;执行 git push origin master后此时报错 问题描述 问题&#xff1a; git push 本地文件 到 另一个远程仓库时&#xff0c;运行 git push origin master ,push文件失败&…

革命性的写作:MDX 让你的 Markdown 全面动起来

1. MDX MDX 是一种标记语法&#xff0c;它结合了 Markdown&#xff08;一种流行的文本到 HTML 的转换工具&#xff09;和 JSX&#xff08;React 中用于描述 UI 组件的语法扩展&#xff09;。MDX 允许你在 Markdown 文档中直接写入 JSX&#xff0c;这意味着你可以在 Markdown 内…

echarts中绘制3D三维地球

简介 echarts中的三维地球&#xff0c;需要用到世界地图json数据&#xff0c;我把json文件放到我的资源中&#xff0c;有需要的自行下载。 安装插件 // 安装echats npm install echarts --save npm install echarts-gl --save 项目中引用 1&#xff0c;引入安装的echarts…

数据结构----栈的概念、模拟实现、栈的使用、栈的应用、有关栈的算法题

文章目录 1. 栈(Stack) 的概念2. 栈的模拟实现3. 栈的使用4. 栈的应用场景4.1. 改变元素的序列4.2. 将递归转化为循环4.3. 150.逆波兰表达式求值4.4. 20.括号匹配4.5 JZ31 栈的压入、弹出序列4.6 155.最小的栈 5. 概念区分 1. 栈(Stack) 的概念 栈&#xff1a;一种特殊的线性表…

vue3中如何实现图片的压缩

首先&#xff0c;为什么需要进行图片压缩&#xff1a; 减少页面加载时间&#xff1a;因为图片是页面中常见的资源之一&#xff0c;较大的图片会增加页面的加载时间&#xff0c;影响用户体验&#xff0c;压缩图片可以减小图片的文件大小&#xff0c;提升页面加载速度。节省网络…

2024年【上海市安全员B证】最新解析及上海市安全员B证复审考试

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 上海市安全员B证最新解析根据新上海市安全员B证考试大纲要求&#xff0c;安全生产模拟考试一点通将上海市安全员B证模拟考试试题进行汇编&#xff0c;组成一套上海市安全员B证全真模拟考试试题&#xff0c;学员可通过…

STC系列单片机定时器

目录 一、定时器的概念 二、单片机程序中的定时器功能代码的实现 &#xff08;1&#xff09;TMOD &#xff08;2&#xff09;AUXR &#xff08;3&#xff09;初始化TH0和TL0 &#xff08;4&#xff09;TR0/EA/ET0三个寄存器 一、定时器的概念 关于定时举个简单的例子&…

Mybatis基础教程及使用细节

本篇主要对Mybatis基础使用进行总结&#xff0c;包括Mybatis的基础操作&#xff0c;使用注解进行增删改查的练习&#xff1b;详细介绍xml映射文件配置过程并且使用xml映射文件进行动态sql语句进行条件查询&#xff1b;为了简化java开发提高效率&#xff0c;介绍一下依赖&#x…

电源芯片并联使用-AMS1117

自记&#xff1a; 电源芯片可不可以并联使用&#xff1a; 1.按照正规大厂Rohm的技术文档介绍&#xff0c;直接并联的两个LDO&#xff0c;只要其输出电压有很小的差异&#xff0c;就会造成电流分配的很大差异。 至于你长期使用没有发现问题&#xff0c;那可能是总电流的余量留…