搜索
bottom↓
回复: 8

AES算法 加密解密数据部分出错的问题

[复制链接]

出0入0汤圆

发表于 2018-11-23 11:25:27 | 显示全部楼层 |阅读模式
本帖最后由 a312835782 于 2018-11-23 11:29 编辑

最近想用AES加密 IAP,找了一个工具,把bin文件加密。用的AES128

   我从加密后的头32字节拿来解密是能正确解密。  但比如我从第16字节取16字节来解密就不对了。
   如果我从第16字节取32字节来解密, 得出来的结果,前16字节是错误的,后16字节是正确的。
  
是哪里不对吗?

1.将文件加密


2.把加密后的头32字节拿来解密,结果正确。


3.把第16字节取32字节来解密,前16字节错误,后16字节结果正确


4.单独取16字节解密,结果是错误的

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

阿莫论坛20周年了!感谢大家的支持与爱护!!

一只鸟敢站在脆弱的枝条上歇脚,它依仗的不是枝条不会断,而是自己有翅膀,会飞。

出590入1001汤圆

发表于 2018-11-23 11:30:48 | 显示全部楼层
加密或者解密之后,重新初始化一下密钥,记得之前从网上下载的一个AES加密,会把上次的结果作为下次的密钥。你试试看

出0入0汤圆

 楼主| 发表于 2018-11-23 11:35:26 | 显示全部楼层
本帖最后由 a312835782 于 2018-11-23 11:38 编辑
SUPER_CRJ 发表于 2018-11-23 11:30
加密或者解密之后,重新初始化一下密钥,记得之前从网上下载的一个AES加密,会把上次的结果作为下次的密钥 ...


我是用工具来试的,还没用代码来算

怎么重新初始化密钥呢?     我重启了软件,计算也是一样的


难道意思是上16字节计算结果当下一次的密钥吗?

好像不对


本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

出0入8汤圆

发表于 2018-11-23 11:39:22 | 显示全部楼层
选 ECB 模式,就能实现你的需求。

出0入0汤圆

发表于 2018-11-23 11:39:25 | 显示全部楼层
void AES_ECB_128bit_Encrypt(unsigned char * dat, unsigned long Len)
{
    unsigned char chainCipherBlock[16] = {0};
    unsigned long cnt = 0;
    //    memset(chainCipherBlock, 0x00, sizeof(chainCipherBlock));
    aesEncInit();/* 在执行加密初始化之前可以为AES_Key_Table赋值有效的密码数据 */

    /* AES加密,数组dat里面的新内容就是加密后的数据。 */
    /* AES源数据大于16字节时,把源数据的指针+16就好了 */
    for(cnt = 0; cnt < Len; cnt += 16)
        aesEncrypt(dat + cnt, chainCipherBlock);
}

出0入0汤圆

 楼主| 发表于 2018-11-23 11:43:42 | 显示全部楼层
security 发表于 2018-11-23 11:39
选 ECB 模式,就能实现你的需求。

卧槽,  还真是,ECB确实是我想要的。

cbc可能是跟前一次计算有关系。

出0入0汤圆

 楼主| 发表于 2018-11-23 11:44:13 | 显示全部楼层
boboo 发表于 2018-11-23 11:39
void AES_ECB_128bit_Encrypt(unsigned char * dat, unsigned long Len)
{
    unsigned char chainCipherB ...

谢谢,确实是ECB。

出0入8汤圆

发表于 2018-11-23 11:45:03 | 显示全部楼层
a312835782 发表于 2018-11-23 11:43
卧槽,  还真是,ECB确实是我想要的。

cbc可能是跟前一次计算有关系。

CBC 是链式的。
你去查一下 ECB 和 CBC ,就知道问题原因了。

出0入0汤圆

 楼主| 发表于 2018-11-23 11:46:57 | 显示全部楼层
security 发表于 2018-11-23 11:45
CBC 是链式的。
你去查一下 ECB 和 CBC ,就知道问题原因了。

好的,谢谢
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-6-18 22:26

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表