AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 467636
Accepted
ens
ens
Asked: 2018-09-08 14:25:37 +0800 CST2018-09-08 14:25:37 +0800 CST 2018-09-08 14:25:37 +0800 CST

在普通模式下使用 dm-crypt 重用密钥的安全性?

  • 772

从密码分析的角度来看,在 dm-crypt 普通模式和 cypher 中为不同卷重用相同密钥时是否存在安全缺陷aes-xts-plain64?

# Example: Encrypt two volumes with the same key

cryptsetup --type plain --cipher=aes-xts-plain64 --key-size=256 --key-file mykey open /dev/sda myvol1
cryptsetup --type plain --cipher=aes-xts-plain64 --key-size=256 --key-file mykey open /dev/sdb myvol2

我只考虑使用相同密钥加密少于 100 个卷的实际情况。

dm-crypt
  • 1 1 个回答
  • 404 Views

1 个回答

  • Voted
  1. Best Answer
    frostschutz
    2018-09-08T15:40:34+08:002018-09-08T15:40:34+08:00

    好吧,这不是安全堆栈交换,我也不是密码学专家,但从表面上看:

    爱丽丝未加密:

    00000000  48 65 6c 6c 6f 20 6d 79  20 6e 61 6d 65 20 69 73  |Hello my name is|
    00000010  20 41 6c 69 63 65 0a 00  00 00 00 00 00 00 00 00  | Alice..........|
    00000020  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
    

    鲍比未加密:

    00000000  48 65 6c 6c 6f 20 6d 79  20 6e 61 6d 65 20 69 73  |Hello my name is|
    00000010  20 42 6f 62 62 79 0a 00  00 00 00 00 00 00 00 00  | Bobby..........|
    00000020  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
    

    两者都使用相同的(主)密钥 aes-xts-plain64 加密:

    Alice000  8f 04 35 fc 9f cb 5d c8  af da ae 78 cd e5 64 3d  |..5...]....x..d=|
    Bobby000  8f 04 35 fc 9f cb 5d c8  af da ae 78 cd e5 64 3d  |..5...]....x..d=|
    Alice010  4f d3 99 77 7b c1 2c 8d  ff 9b 4d 55 da a3 9b e2  |O..w{.,...MU....|
    Bobby010  12 d6 ad 17 74 50 4d 08  8c 38 22 40 98 a7 14 99  |....tPM..8"@....|
    Alice020  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
    Bobby020  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
    

    所以——从外观上看,一个问题是相同的偏移量和明文(对于每个 16 字节块)导致相同的密文。如果明文不同,密文也不同。在某些情况下,这可能比显示可用空间更具启发性。

    另一个问题是您可以将密文从一个驱动器复制到另一个驱动器,然后将其解密为有意义的数据——但在错误的驱动器上。通常,如果您弄乱密文,解密时得到的只是随机垃圾,但重新使用万能钥匙只会为您提供更有效的密文。

    因此,完全人为的示例,如果您的用户不知道密钥,但以某种方式可以访问存储在该系统上的文件,并且能够将密文从一个驱动器复制到另一个驱动器-通常不可能,但让我们假设就是这样。他们可以写一个充满废话的大文件,找出这个文件在磁盘上的分配位置,然后从其他驱动器复制数据。然后在读回文件时以明文形式查看另一个驱动器数据。

    总而言之,当为每个磁盘使用唯一密钥非常容易时,这只是一个不必要的头痛。即使您使用散列函数或其他方法从共享主密钥中派生该密钥。虽然也没有理由。--keyfile-offset您可以只使用多个密钥文件,或者使用,--keyfile-size选项从单个文件中读取多个密钥。

    LUKS 应该可以帮助您避免各种陷阱。除非您故意克隆标头,否则它始终为每个容器使用不同的随机主密钥,即使您为它们使用相同的密码。


    还有一点关于您选择的密码的说明,aes-xts-plain64. 这曾经被称为aes-xts-plain. 一切都很好,直到出现大于 2TiB 的设备......aes-xts-plain密文每 2TiB 重复一次,这与重复使用相同的主密钥基本上是相同的问题。

    这已通过 修复aes-xts-plain64,但一些博客/wiki 仍然推荐旧的,或者旧的容器与新的硬盘驱动器一起保留和增长,所以有些人最终还是使用了错误的...

    • 4

相关问题

  • 使用 dm-crypt 整个系统加密 (BIOS) 安装后无法启动 Arch Linux

  • veritysetup 验证成功,但升级到新内核后挂载失败

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve