- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要编写一个简化的加密 API,它可以通过使用随机生成的 key 或密码派生的 key 轻松处理对称加密。
密码生成是使用 OpenSSL 库中的 PKCS5_PBKDF2_HMAC() 函数并使用 EVP_sha256() 作为哈希算法和随机生成的 16 字节盐来执行的。
对称加密是使用 OpenSSL EVP API 执行的。
我的问题是:将密码派生盐也用作加密的 IV 有多(不)安全?
这个问题背后的原因是,这将允许我以下列方式简化 API 和输出流:
注意:API 会自动处理 salt/IV 生成,这是为每个加密 session 随机生成的,因此即使重复使用密码,也保证 key 是不同的。
预先感谢您的回答。
最佳答案
碰巧的是,我在处理我自己的一个项目时遇到了几乎完全相同的场景(其中一条消息在 CBC 模式下使用随机 IV 加密,用户可以指定一个 key 或文本密码)。
类似问题讨论here和 here .总结一下:IV 的目的是确保即使 key 被重复使用,密文也保持唯一。只要您像您所说的那样为每条消息生成一个新的 IV, key 的来源就无关紧要。这意味着你可能安全地重复使用盐作为 IV,就目前任何人所知。它甚至看起来甚至没有意义成为一个问题,因为在以不同的方式派生 key 之前,盐会通过加密散列;只要您在 PBKDF2 中使用良好的哈希函数(即上面提到的 SHA-256),这样派生的 key 就无法与随机生成的 key 区分开来,在这种情况下可能是随机生成的。
但是,人们总是在密码分析的世界中发现意想不到的事情,即使我们不知道,直接在两个地方重复使用相同的数据在原则上也被认为是一件坏事任何实际问题就在这一刻。你真的应该为此担心吗?以我对密码分析的知识水平,我介于“也许”和“我不知道”之间,这对我的口味来说有点太不确定了,所以我将采用“技术上更安全”的行动方案,它生成单独的 IV 和盐值。 Transmitting both the salt and the IV is a perfectly cromulent security practice ,如果用户直接输入 key 并且盐未被使用,您也不会有任何损失。
关于salt - 在基于密码的加密中使用密码盐作为 IV,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16786743/
在设置了 salt-master 和一个 minion 后,我可以接受 master 上的 key 。运行 sudo salt-key -L表明它被接受。但是,当我尝试使用 test.ping 时命令
当我使用管道运行任何命令或在其中重定向时,它会失败。 master 和 minion 都在为测试 Salt 而创建的 Digital Ocean 上的新 Ubuntu 14.04 机器上运行。 两者都
这里的 Salt 中 [] 是什么意思? httpd: pkg.installed: [] file.managed: - name: /etc/httpd/conf/httpd.co
我正在寻找一种简单的方法来获取有关内存使用情况的信息,例如盐小兵的空闲内存。 到目前为止,我知道可以使用salt '*' grains.items列出总内存,但是我什至不知道如何仅列出总内存而不是所有
在 Saltstack 中,我有以下用例: 有一个状态 redis.sls 可以被其他状态包含。 redis.sls 的结果应该根据包含 redis.sls 的状态进行不同的配置。 例如: redis
我有一个带有盐状态的存储库,用于在云中配置我的服务器集群。随着时间的推移,我不断添加更多状态 - .sls文件 - 进入这个 repo。现在我开始挣扎什么是什么,什么是哪里。 我想知道是否有一些软件实
有没有办法加入两个支柱文件? 我有一个用户支柱。它是这样的: users: joe: sudouser: True jack: sudouser: False 现在我需要为某些
我在家庭实验室中使用 Saltstack,在测试它们时,我经常发现自己检查了一些稍有破坏的规则。我希望能够检查它们的有效性,否则在本地和 Jenkins 实例上对它们进行 lint,但我找不到任何有关
我有一个场景,如果另一个服务已经在运行,我需要采取行动。具体来说,我想安装 snmp 监控,例如,如果 mysql 已经在运行。 我知道这样做的“正确”方法是安装 mysql 及其基于支柱数据、gra
我正在尝试构建一个总是会重启服务的 .sls 文件: systemd-resolved: service.running: - restart: True 部署后,这会给出 I
(这是我在 salt 用户组 FWIW 上提出的问题的副本) 我需要编写一个状态来安装一些Windows服务器功能,重新启动minion,然后安装更多软件。似乎所有的部分都在那里(cmd.wait、s
“salt”在字符串到键 (s2k) 说明符中指什么? 它似乎是一个随机数生成器,可以改变事物,但我想知道“盐”代表什么? 例如这样写: 3.6.1.2. Salted S2K This inc
我正在尝试构建一个总是会重启服务的 .sls 文件: systemd-resolved: service.running: - restart: True 部署后,这会给出 I
我有一个 AWS 设置,其中有一个指定的 salt master,它接受所有传入的 key 和基于子网/指定 ip 地址的规定。如何在不登录主服务器的情况下立即在连接时配置我的 minions? 最佳
我想要一个 Salt 状态来管理我的 SSH 文件。这需要多个 file.line操作。我怎样才能做到这一点? 更新:请参阅问题底部以了解我当前的解决方法 我有的是这个: Secure SSH:
我正在验证用户电子邮件地址。 大多数人告诉的方式是创建一些独特的 token 并将其存储在 db 中 发送给用户。 我只是用全站盐散列(sha256)电子邮件地址来做这件事 并将此哈希发送给用户。 我
国家file.managed has defaults和 context模板渲染选项。两者都为模板变量提供上下文。 它们之间有什么区别? 最佳答案 defaults是在 context 情况下将传递给
我刚开始使用 Salt 而不是 Ansible。我不确定是从 master 调用以下脚本还是手动将命令输入 salt 状态。对于后者,任何人都可以建议如何使用 cmd.run 实现此目的。 #!/bi
我刚开始使用 Salt 而不是 Ansible。我不确定是从 master 调用以下脚本还是手动将命令输入 salt 状态。对于后者,任何人都可以建议如何使用 cmd.run 实现此目的。 #!/bi
我用了一个月的 salt 。每当我运行命令说 sudo salt '*' test.ping 时,master 就会对所有 minions 执行 ping 操作,响应是所有已启动并正在运行的 mini
我是一名优秀的程序员,十分优秀!