AES补位填充的一个问题

Posted xuhui24

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了AES补位填充的一个问题相关的知识,希望对你有一定的参考价值。

AES加密支持多种填充方式,NoPadding,PKCS5Padding,ISO10126Padding,ZerosPadding,PKCS7Padding。

其中PKCS7Padding 就是数据个数最后少几个就填充多少个数,具体的做法可以:数据的个数先取余16,然后16减去余数。

例如{1,2,3,4,5,6,7,8,9},总共9个数值,取余16后是9,需要补充7个7,则最后数据变为{1,2,3,4,5,6,7,8,9,7,7,7,7,7,7,7}

需要特别注意一种情况如果数据的个数刚好是16的倍数,那就要在补充16个字节(一定要)。例如{1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16},填充后的数据是{1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16}

ZerosPadding就是缺少多少位就补充多少个0,基本流程相同。

以上是关于AES补位填充的一个问题的主要内容,如果未能解决你的问题,请参考以下文章

Question20180128 补位的两种方式

Java Cipher - AES 填充问题

java中的Aes解密-填充问题

GGplot2 - aes(填充)的问题

AES 填充并将密文写入磁盘文件

aes算法填充方式