aes ios加密 java解密_关于AES256算法java端加密,ios端解密出现无法解密问题的解决方案...

我想关于AES算法大家应该都已经了解了,我就不多介绍了。这是本人第一次写技术博文,如果有不对之处欢迎大家指正,共同讨论,一起学习!

之前在项目上用到AES256加密解密算法,刚开始在java端加密解密都没有问题,在iOS端加密解密也没有问题。但是奇怪的是在java端加密后的文件在iOS端无法正确解密打开,然后简单测试了一下,发现在java端和iOS端采用相同明文,相同密钥加密后的密文不一样!上网查了资料后发现iOS中AES加密算法采用的填充是PKCS7Padding,而java不支持PKCS7Padding,只支持PKCS5Padding。我们知道加密算法由算法+模式+填充组成,所以这两者不同的填充算法导致相同明文相同密钥加密后出现密文不一致的情况。那么我们需要在java中用PKCS7Padding来填充,这样就可以和iOS端填充算法一致了。

要实现在java端用PKCS7Padding填充,需要用到bouncycastle组件来实现,下面我会提供该包的下载。啰嗦了一大堆,下面是一个简单的测试,上代码!

package com.encrypt.file;

import java.io.UnsupportedEncodingException;

import java.security.Key;

import java.security.Security;

import javax.crypto.Cipher;

import javax.crypto.SecretKey;

import javax.crypto.spec.SecretKeySpec;

public class AES256Encryption{

/**

* 密钥算法

* java6支持56位密钥,bouncycastle支持64位

* */

public static final String KEY_ALGORITHM="AES";

/**

* 加密/解密算法/工作模式/填充方式

*

* JAVA6 支持PKCS5PADDING填充方式

* Bouncy castle支持PKCS7Padding填充方式

* */

public static final String CIPHER_ALGORITHM="AES/ECB/PKCS7Padding";

/**

*

* 生成密钥,java6只支持56位密钥,bouncycastle支持64位密钥

* @return byte[] 二进制密钥

* */

public static byte[] initkey() throws Exception{

// //实例化密钥生成器

// Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());

// KeyGenerator kg=KeyGenerator.getInstance(KEY_ALGORITHM, "BC");

// //初始化密钥生成器,AES要求密钥长度为128位、192位、256位

kg.init(256);

// kg.init(128);

// //生成密钥

// SecretKey secretKey=kg.generateKey();

// //获取二进制密钥编码形式

// return secretKey.getEncoded();

//为了便于测试,这里我把key写死了,如果大家需要自动生成,可用上面注释掉的代码

return new byte[] { 0x08, 0x08, 0x04, 0x0b, 0x02, 0x0f, 0x0b, 0x0c,

0x01, 0x03, 0x09, 0x07, 0x0c, 0x03, 0x07, 0x0a, 0x04, 0x0f,

0x06, 0x0f, 0x0e, 0x09, 0x05, 0x01, 0x0a, 0x0a, 0x01, 0x09,

0x06, 0x07, 0x09, 0x0d };

}

/**

* 转换密钥

* @param key 二进制密钥

* @return Key 密钥

* */

public static Key toKey(byte[] key) throws Exception{

//实例化DES密钥

//生成密钥

SecretKey secretKey=new SecretKeySpec(key,KEY_ALGORITHM);

return secretKey;

}

/**

* 加密数据

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值