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
    +关注

    关注

    146

    文章

    16022

    浏览量

    343694
  • 接收器
    +关注

    关注

    14

    文章

    2215

    浏览量

    70673
  • soc
    soc
    +关注

    关注

    38

    文章

    3750

    浏览量

    215724
收藏 人收藏

    评论

    相关推荐

    MCU在线技术讲座-EFM和EFR: 面向联网开发的通用MCU平台

    : 面向联网开发的通用MCU平台”。 本次技术讲座将详细说明以芯科科技8位和32位MCU,以及无线SoC作为联网开发通用平台的诸多
    发表于 11-23 13:45

    联网专业前景怎么样?

    联网专业是一个具有广阔前景和就业机会的领域。通过系统的专业学习和实践经验,从事物联网相关的工作将有机会参与到技术创新和社会发展,带来具有挑战性和成就感的职业生涯。
    发表于 10-20 09:48

    MCU是怎么为联网端点设备提高安全性的?

    MCU 是怎么为联网端点设备提高安全性的?
    发表于 10-17 08:53

    基于飞腾派的边缘联网

    网络连接实现远程控制和监管。还可以通过手机 APP 或云端平台控制教室的设备,以及监管设备的运行状态和故障情况。边缘联网关在智慧教室场景
    发表于 09-21 16:50

    联网简介

    联网(IoT)是由物理设备、车辆等组成的网络,家用电器和嵌入有电子设备、软件、传感器等的其他物品,致动器,以及使这些物体能够连接和交换数据。
    发表于 09-11 07:18

    15个常见的C语言陷阱及其解决方法

    C语言是一种非常流行的编程语言,因为它简单易学,且广泛应用于各个领域。但是,由于C语言本身的特性,它也容易引起一些错误和陷阱,这些错误可能导致程序崩溃、数据丢失或者安全漏洞等问题。本文将介绍15个常见的C语言
    发表于 09-09 14:51 975次阅读

    ARM联网整体解决方案-数据表

    ARM联网整体解决方案提供了一种独特的基于解决方案的方法,将最新的专业处理能力与先进的软件和工具相结合。 ARM联网整体解决方案可随时实施
    发表于 08-29 06:06

    新唐对应四大联网安全攻击的保护措施

    联网安全包含装置安全和网络安全,在此定义下涵盖了保护联网设备和网络所需的流程、技术和防护措施。
    发表于 08-21 08:14

    浅谈工业联网平台

    (PaaS)、应用层(SaaS)三大核心层级,除此之外,工业互联网平台还包括 IaaS 基础设施,以及涵盖整个工业系统的安全管理体系。工业云平台KMM工业云平台是基于“工业互联网平台体
    发表于 08-10 15:45

    设计一个片上系统-为安全联网创建一个系统设备

    本指南适用于系统设计人员,可能使用Arm Flexible access。我们假设您希望为安全联网设备开发片上系统(SoC),并且您打算SoC将用于智能咖啡机。然而,该指南可能与任何相关的
    发表于 08-02 09:33

    联网:RFID安全(2)#联网

    联网
    学习硬声知识
    发布于 :2023年07月07日 12:06:17

    联网:RFID安全(1)#联网

    联网
    学习硬声知识
    发布于 :2023年07月07日 12:05:23

    介绍9种PCB常见处理工艺以及它们的适用场景

    PCB表面的处理工艺多种多样,这里介绍9种常见的处理工艺,以及它们的适用场景
    发表于 06-29 14:18 2293次阅读

    超低功耗MCU在联网方案的应用

    ,超低功耗MCU在联网方案的应用有哪些呢? 一、传感器设备 联网的传感器设备是非常
    发表于 06-13 18:18

    联网台如何保证数据的安全性?#大数据台 #光点科技

    联网
    光点科技
    发布于 :2023年06月01日 18:08:09