首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么php通过mcrypt_encrypt()生成的密文长度与C通过openssl加密库生成的密文长度不同?

为什么php通过mcrypt_encrypt()生成的密文长度与C通过openssl加密库生成的密文长度不同?
EN

Stack Overflow用户
提问于 2014-11-24 08:27:22
回答 1查看 103关注 0票数 0

我尝试了openssl wiki中的this code,它通过aes-256算法生成密文。输入纯文本的长度为512字节。然而,输出的长度是不同的。PHP生成长度为512字节的输出,而C生成长度为528字节的密文。

为什么存在这样的差异?我如何使用aes-256算法在PHP中加密文本,然后在C中解密?

EN

回答 1

Stack Overflow用户

发布于 2014-11-24 08:34:09

例如,您应该查找mcrypt_encrypt的注释部分,使用PKCS#7填充方法填充明文消息。PHP使用零填充,直到块边界上的第一个值,而不是通常使用的即席PKCS#7填充方法。

零填充的问题在于,对于可能以00字节值结束的消息,它不是确定性的,因为这可能会在取消填充期间被移除。

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

https://stackoverflow.com/questions/27096158

复制
相关文章

相似问题

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