使用openssl对文件进行aes加密
admin
2024-01-21 20:01:25
0

项目中需要对文件进行加密和解密,考虑通过openssl来做,因此这两天尝试去搞了一下。参照csdn上的一些源码去实现了一下,稍微有点问题。主要是加密后再解密时,尾部有乱码。一开始找不到原因,于是考虑不写代码,直接调用openssl来做加密,解密,看看会不会有问题。命令很简单:

加密环节:

openssl enc -e -aes-128-cbc -pass file:./keyFile -in plainFile -out encryptFile

-e表示加密

-aes-128-cbc:aes表示加密的方法基于aes标准,128是密钥长度,cbc是aes中一种。aes除了cbc还有ecb,cfb等。具体有哪些用openssl enc -e -list可以查看。

-keyFile就是保存对称密钥的文件

-plainFile是要加密的文件,也就是明文文件

-encryptFile就是加密后的文件

解密环节:

openssl enc -d -aes-128-cbc -pass file:./keyFile -in encryptFile -out plainFile

-d表示解密。

其它的参数很容易看明白。

测试的结果,发现,通过命令行调用的话,解密后的文件非常正常,没有乱码。

之后用代码去实现,无非就是通过system(char* cmd)函数去调用上面两个命令,结果也是好的。

那说明前面通过代码的方式去实现,某个细节上有问题。后来查到了一篇文章,链接如下:

[Solved] AES 256-cbc encryption C++ using OpenSSL | 9to5Answer

原因就在于加密是分段进行的,aes-128的话,每段的长度为16个字节。如果文件的长度,不能被16整除,剩余的字节,凑不够16个的话,需要进行填充(padding),而且用0填充。

size_t inputslength = message.length();//原始文件的长度

unsigned char aes_input[inputslength];

unsigned char aes_key[AES_KEYLENGTH];//秘钥长度

const size_t encslength = ((inputslength + AES_BLOCK_SIZE) / AES_BLOCK_SIZE) * AES_BLOCK_SIZE;//真正加密的时候,明文的长度(填充后的)

unsigned char enc_out[encslength];

unsigned char dec_out[inputslength];

memset(enc_out, 0, sizeof(enc_out)); memset(dec_out, 0, sizeof(dec_out));//填充部分变为0

AES_cbc_encrypt(aes_input, enc_out, inputslength, &enc_key, iv, AES_ENCRYPT);//加密,密文长度可能比明文长度大

按照这种去操作,尾部出现乱码的问题就消失了

相关内容

热门资讯

原创 4... 写在文章前的声明:在本文之前的说明:本文中所列的投资信息,只是一个对基金资产净值进行排行的客观描述,...
胜宏科技港股大涨49% 做完英... 记者 陈月芹 4月21日,全球AI算力板龙头胜宏科技(02476.HK)登陆港交所,上市首日股价大涨...
永赢基金:聚焦“科技新锐”,科... 数据来源:Wind,时间统计区间为2025/1/1-2026/4/21,指数过往表现不预示未来,不构...
五大阅读趋势显现!当当网发布2... 在第31个世界读书日即将来临之际及首个全民阅读活动周期间,当当网正式发布2026国民阅读洞察报告。 ...
业绩逐季回暖 老百姓大药房一季... 上证报中国证券网讯(记者 夏子航)4月22日晚,老百姓大药房发布2025年年报和2026年一季报。今...
中国20强城市大洗牌:苏州接近... 中国的城市经济竞争格局一直在变化,每年发布的GDP数据都会对城市经济实力进行重新排列。2025年榜又...
直击金宏气体股东会:预期年内氦... 《科创板日报》4月22日讯(记者 郭辉)金宏气体日前举行2025年度股东大会。会上该公司审议了公司年...
5月1日起,俄据悉将叫停哈萨克... 据行业消息人士透露,俄罗斯将于5月1日起停止经友谊管道转运哈萨克斯坦输往德国的石油,相关调整计划已送...
深化具身智能生态布局 京东携手... 4 月 22 日,京东与国内消费级人形机器人头部企业松延动力正式达成三年期战略合作。双方将围绕产品研...
原创 帮... 先问你一个问题,美伊停火今晚到期,按常理避险情绪该升温,黄金应该涨吧?结果恰恰相反——原油涨了,黄金...
300295、600889,将... 三六五网、南京化纤,将被*ST。 公司股票自4月23日开市起停牌一天,于4月24日开市起复牌并实施退...
能源大变天!外媒:羡慕中国的石... 这一次油价突破 110 美元的能源危机,着实魔幻。如果放在十年前,没人会相信中国能在这场风波中获利,...
黄金涨跌两难,现在还能上车吗? 中新网4月22日电(记者 左雨晴) 四月以来,美伊局势反复拉扯,美联储降息预期一变再变。黄金价格在4...
“我身体健康”,库克现身员工大... 当地时间4月21日,受苹果官宣CEO换届影响,公司股价盘中下探超2%,总市值失守4万亿美元关口,收盘...
库克留下一个悬念 工程师能否拯救创新节奏? 听筒Tech(ID:tingtongtech)原创 文 | 赵 森 ...
探索消费信贷与社交支付深度融合... 腾讯这一金融产品再添新功能,4月19日,北京商报记者注意到,微信分付灰度测试转账功能引发热议,在向微...
土耳其主要银行股指早盘下跌2% 每经AI快讯,4月20日,土耳其主要银行股指早盘下跌2%。 每日经济新闻
好用的OTA代运营源头厂家 在如今竞争激烈的酒旅行业中,OTA代运营服务成为了众多酒店、民宿提升竞争力的关键。但市场上的代运营厂...
成都五一出游全国热门第三 “五一”假期临近,同程旅行最新发布的《2026“五一”旅行趋势报告》显示,今年“五一”期间成都同时位...