首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >PHP: Mcrypt -哪种模式?

PHP: Mcrypt -哪种模式?
EN

Stack Overflow用户
提问于 2011-02-25 01:43:39
回答 1查看 12.1K关注 0票数 17

我一直在测试PHP的mcrypt函数中提供的各种modes。ECB是大多数教程中使用的模式,但并不是刚链接的页面和some users都推荐使用的模式,所以我认为CBC或CFB中的任何一个都可以做到这一点。

PHP文档在比较mcrypt可用的不同模式时并不是太多,而是参考了“Schneier的应用密码学”这本书,我目前不太想买这本书。

那么,我应该使用哪种mcrypt-modes ?为什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-02-25 04:02:39

listed相比,mcrypt实际上实现了更多的模式,您可以使用字符串名称来访问它们:

  • cbc - CBC mode
  • cfb -8位CFB mode;
  • ncfb -块大小CFB mode;
  • nofb - OFB模式(非ofb);
  • ctr - CTR模式。

这些模式在实现细节上有所不同,因此它们的适用性取决于您的数据和环境。

填充

除非您实现了自己的padding.

  • CFB,

  • 和CTR模式来加密任意长度的消息,否则mcrypt会用零字节填充您的明文。

初始化向量

  • CBC和CFB模式需要一个随机IV (不要使用deleted).
  • CTR模式,只需要一个唯一的IV (例如,全局计数器,如果行从未被修改,则可能是数据库主键),或者要求每个计数器块是唯一的(不仅仅是消息的IV,它是第一个计数器块,其余的是通过为每个消息块将计数器块递增1而形成的)。

有关更多信息,请参阅NIST recommendations

性能上的差异在PHP中是不重要的,比如加密或解密是否可以并行化,以及每个块使用了多少次密码迭代(通常是一次,但在8位CFB模式下是16次)。

malleability中存在一些差异,这些差异应该不重要,因为您将应用MAC

它们的安全性可能会有所不同,但为此您应该咨询cryptographer

票数 22
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5108408

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档