0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

物联网安全实施中的常见陷阱以及如何避免它们

星星科技指导员 来源:嵌入式计算设计 作者:Brent Wilson 2022-06-08 09:25 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

本文特别关注通常由电池供电并运行轻量级、低带宽射频协议的小型无线连接系统。

明文披露

明文披露是指以“明文”或未加密的方式交付或存储的秘密,例如密钥或敏感数据。大多数传输漏洞适用于通过未加密通道传递的敏感用户数据,例如登录凭据。存储漏洞包括敏感的用户数据和密钥,这是一次性物联网设备需要特别关注的领域。我们大多数人在处理笔记本电脑智能手机时都会小心谨慎,以确保敏感信息已被适当删除。在连接灯泡时,您是否同样小心?“垃圾箱攻击”是指从废弃设备中提取敏感信息(例如 Wi-Fi 凭据)。

中间人攻击

“中间人” (MITM) 是一种攻击,攻击者在其中秘密中继并可能改变认为他们直接相互通信的两方之间的通信。MITM 攻击的漏洞表明身份验证存在弱点。在将新设备引入网络时,通常会在调试期间执行这种类型的漏洞利用。有多种方法可用于验证设备以使其安全地加入网络。其中一些需要用户干预,例如输入 PIN 码 (BLE) 或扫描条形码 (Z-Wave)。其他的可以在没有用户干预的情况下发生,例如使用设备证书与证书颁发机构和/或云服务相结合来提供身份验证。

MITM 最常见的实施问题要么是未能包含身份验证(例如,BLE 中的“Just Works”配对方法),要么是未能使用受信任的第三方(例如证书颁发机构 (CA))正确验证证书。

蛮力攻击

“蛮力”攻击试图利用密码系统实施中的弱点。如果实施得当,破解密码系统所需的努力可以在理论上进行估计,并且很容易超过计算的可能性。但是,实施中的弱点会大大减少整体解决方案的空间,将不可能的事情变成可行甚至容易的事情。示例包括弱密码、加密功能的不当使用、硬编码密钥和熵不足。

弱密码

由于计算能力的提高以及发现加密弱点的进步,许多早期的密码系统已经过时。例如,使用 40 位密钥对密码进行暴力攻击需要约 1.1 万亿次测试。这听起来可能是一个很高的数字,但如果再加上当今显卡、FPGA 或云服务的计算能力,就显得不够了。

2017 年,比利时鲁汶大学的研究人员成功破解了 DST40,这是早期特斯拉 Model S 密钥卡中使用的 40 位密码。“假冒 fob”攻击使用连接到 Raspberry Pi 的 RF 接收器“嗅探”汽车的标识符 RF 信标,从汽车请求随机挑战短语,计算并传输对挑战的正确响应,然后可以使用解锁车门或启动汽车,只需大约两秒钟。该系统使用包含所有可能的挑战短语的 5.4 TB 数据结构来查找正确的响应。破解密码的蛮力工作,使用相同的 Raspberry Pi 需要 777 天,之前使用更强大的计算资源预先计算。

这种攻击的对策是不选择弱密码,特别是如果那些密码已经被破解。上面的 DST40 密码最初在 2005 年被约翰霍普金斯大学和 RSA 实验室的一个团队破解,并在 2005 年的福特 Escape SUV 上以类似的方式进行了演示。其他已被证明较弱的流行密码包括 DES、3DES、RC2 和 RC4。在 TLS 连接或协商密码或密码套件的任何连接的情况下,不允许使用弱协议(例如 SSL)或弱密码套件非常重要。

密码学功能的不当使用

高级加密标准 (AES) 是一种分组密码,它对固定大小为 128 位(16 字节)的数据元素进行操作。在对长度超过 16 字节的数据流进行加密或解密时,需要进行多次 AES 操作。独立处理每个块(称为“AES_ECB”或“电子密码本”)可以揭示密文数据中的某些模式,这对于机密性来说是不可取的,因此建议使用 NIST 批准的链式密码模式,例如 AES_CBC(“Cipher Block Chaining”)或 AES_CTR(“计数器”),或者更好的是,使用经过身份验证的加密模式,例如 AES_CCM(“带有 CBC-MAC 的计数器”)或 AES_GCM(“Galois/计数器模式”),这可以确保机密性和真实性的数据。

请注意,其中许多模式都需要使用初始化向量 (IV),其安全要求取决于所选的特定模式。保守的指导是使用强随机数,例如来自经批准的密码随机数生成器,并且只使用一次 IV,使其成为“随机数”。IV 最常见的错误是使用硬编码或常量 IV。

硬编码键

“硬编码”密钥是指嵌入在源代码中的密钥。硬编码密钥不好,因为它们难以更改(需要重新编译源代码),并且它们是最容易窃取的密钥之一(通过逆向工程、阅读源代码或其他方式)。理想情况下,密钥在需要时计算或以加密形式存储。NIST SP 800-57 建议根据密钥的使用方式定期更改密钥,通常每 1 到 3 年或更频繁。此外,系统还应该支持一种机制,用于在密钥被泄露的情况下撤销密钥。

熵不足

密码学依赖于具有高熵的随机数源。一个常见且看似无害的密码学实现错误之一是选择了错误的随机数源。当开发人员使用编译器原生的“rand()”函数而不是加密的强伪随机数生成器 (PRNG) 或者他们使用具有错误种子值(例如常量或时间参考)的良好 PRNG 时,就会发生这种情况。

图 2 显示了使用“rand()”生成的位图和使用 TRNG(真随机数生成器)生成的位图。请注意“rand()”图片中的莫尔状图案。模式不是随机的,这表明这是熵源的错误选择。

密码学的强度取决于随机数中的熵量。随机数源中的任何模式或偏差都会减少暴力攻击期间测试所需的选项数量。为了说明,我们假设嵌入式系统使用“自上次复位后的系统时钟”作为其“rand()”函数的种子,而“rand()”函数用于在系统初始化期间生成密钥。由于 MCU 在很大程度上是确定性的,因此该系统将倾向于生成相同的密钥或一小组密钥中的一个。如果系统只生成八个唯一密钥,那么密钥是 128 位还是 256 位长都没有关系。该密钥的强度只有三位,因为攻击者只需八次尝试即可确定密钥。此外,C 标准规定“rand()”的周期至少为 232,这在蛮力攻击范围内,这意味着如果攻击者能够辨别 PRNG 序列中的当前位置,所有未来的数字都将是已知的。

幸运的是,许多 MCU 和无线 SoC 都配备了硬件 TRNG 外设,它们提供了极好的熵源。TRNG 是从物理源(例如热能)中获取熵的外围设备。NIST 800-90A/B/C 和 AIS-31 规定了密码学的合适要求。或者,如果使用 TRNG 源定期播种,则可以使用加密 PRNG(例如 CTR_DRBG)。

如果 MCU 没有 TRNG 外设,则可以使用其他外设(例如无线 RF 接收器或 ADC)作为熵源,但必须小心使用这种方法。具体来说,必须将源表征为熵源,以确定其数学属性是否足以满足 NIST 要求的密码学要求。NIST 标准还要求对原始熵源添加健康检查,以确保其保持适当的功能,并添加调节功能(例如 SHA-256)以消除输出中的任何偏差。

审核编辑:郭婷

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • mcu
    mcu
    +关注

    关注

    147

    文章

    18635

    浏览量

    387655
  • 接收器
    +关注

    关注

    15

    文章

    2638

    浏览量

    76347
  • soc
    soc
    +关注

    关注

    38

    文章

    4517

    浏览量

    227672
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    Lora基站在联网应用的重要性

    Lora基站在联网应用具有重要的地位。首先,Lora基站可以实现对联网设备的远程监测和控制,为
    发表于 12-03 07:09

    芯源半导体在联网设备具体防护方案

    一同传输。接收方通过安全芯片对接收的数据进行同样的哈希运算,对比生成的消息摘要与接收到的消息摘要是否一致,以验证数据是否被篡改。例如,工业联网传感器发送的监测数据,通过 SHA -
    发表于 11-18 08:06

    请问如何协同工作来保障联网设备固件安全的?

    固件加密存储和安全启动与固件验证这两种固件安全防护手段,是如何协同工作来保障联网设备固件安全的?
    发表于 11-18 07:30

    联网设备面临的多种安全威胁,数据传输安全威胁和设备身份安全威胁有何本质区别?

    联网设备面临的多种安全威胁,数据传输安全威胁和设备身份安全威胁有何本质区别,实际应用
    发表于 11-18 06:41

    玩转VBAT,电源设计常见陷阱99%都能轻松避开!

    电源设计的VBAT如同一把钥匙,掌握它就能打开成功的大门。本文将教您如何玩转VBAT,从而在电源设计轻松避开高达99%的常见陷阱,确保您的设计既高效又可靠。 在
    的头像 发表于 11-14 15:58 225次阅读
    玩转VBAT,电源设计<b class='flag-5'>常见</b><b class='flag-5'>陷阱</b>99%都能轻松避开!

    学习联网可以做什么工作?

    嵌入式软件和硬件,支持联网设备的功能实现。   数据分析师:负责从联网设备和传感器获取和分析数据,并提供数据支持和决策。   
    发表于 10-11 16:40

    常见联网连接方式有哪些?

    常见联网连接方式
    发表于 09-08 08:26

    电商API常见错误排查指南:避免集成陷阱

    ,帮助您高效避免集成陷阱。内容基于真实电商API实践,确保可靠性和实用性。 一、常见错误类型 电商API集成,错误往往源于认证、数据、限流等环节。以下是高频问题: 认证失败错误 当A
    的头像 发表于 07-11 14:21 1806次阅读
    电商API<b class='flag-5'>常见</b>错误排查指南:<b class='flag-5'>避免</b>集成<b class='flag-5'>陷阱</b>

    联网蓝牙模块有哪些优势?

    之间的互联互通。这使得在联网应用,多个设备可以协同工作,从而提高了系统的整体效率。总之,联网蓝牙模块具有低功耗、传输距离远、
    发表于 06-28 21:49

    工业联网常见的协议有哪些

    工业联网常见的协议有哪些
    的头像 发表于 06-14 15:52 1036次阅读

    联网未来发展趋势如何?

    技术将为人们带来更加安全、便捷和舒适的居住环境。 工业互联网:工业互联网联网行业的热门领
    发表于 06-09 15:25

    联网工程师为什么要学Linux?

    Linux生态已集成MQTT、TCP/IP、ZigBee等联网常用协议栈,开发者可直接调用或移植,避免从零实现协议的复杂性。此外,庞大的开源社区(如Contiki、RT-Thr
    发表于 05-26 10:32

    为什么选择蜂窝联网

    。虽然需要支付订阅费用,但却能保证广泛的覆盖范围、可扩展性、内置服务质量、可靠性和无懈可击的安全性。这样,您就可以专注于特定联网产品的开发,而无需部署和维护与在非授权频段运行的其他 LPWAN 技术相关
    发表于 03-17 11:42

    如何避免直流负载箱的常见操作误区?

    ,可以有效避免直流负载箱的常见操作误区,确保设备的安全稳定运行,延长其使用寿命,同时也能保障操作人员的人身安全
    发表于 02-13 13:49

    联网就业有哪些高薪岗位?

    系统的数据安全和隐私保护,这一岗位的需求也在逐年上升。  随着联网行业的蓬勃发展,这些高薪岗位将持续吸引着大量求职者。然而,高薪并不是唾手可得的,对于求职者而言,还需要具备扎实的技术功底、丰富的实践经验和持续学习的精神。只有
    发表于 01-10 16:47