AES加密算法输出字符串长度(String)错误?

时间:2015-04-10 14:30:08

标签: java encryption aes encryption-symmetric

 public static String encryptKey(String key,String text) throws CryptoException 
    {
        String key1=null;
        try {

            System.out.println("input parameters length  "+key.length()+ " " +text.length());
            System.out.println("input parameters value "+key+ " " +text);
            Key secretKey = new SecretKeySpec(key.getBytes(), ALGORITHM);
            Cipher cipher = Cipher.getInstance(TRANSFORMATION);

            cipher.init(Cipher.ENCRYPT_MODE, secretKey);             
            byte[] inputBytes=text.getBytes();
           //System.out.println(inputBytes.length);
            byte[] outputBytes = cipher.doFinal(inputBytes);
           // key= WriteArray.bytesToString(outputBytes);  
           key1=outputBytes.toString();


            System.out.println("output parameters  "+key1.length()+" "+ text.length());
            System.out.println("output parameters value "+key1+ " " +text);
        } 

输入和输出字符串长度不同。为什么会这样?

转换字符串到字节数组转换的问题是什么?输出如下所示。

--------------------------------------
Level 1 Encryption Started
input parameters length  16 16
input parameters value 5iafq1b7d8i4hedu vg322qcfmnjbp3nj
output parameters  11 16
output parameters value [B@35851384 vg322qcfmnjbp3nj
--------------------------------------
Level 2 Encryption Started
input parameters length  16 11
input parameters value tvqfpjpul28ovo5c [B@35851384
output parameters  11 11
output parameters value [B@649d209a [B@35851384
--------------------------------------

1 个答案:

答案 0 :(得分:0)

不要将加密数据视为字符串。这是二进制数据,当你致电outputBytes.toString()时,几乎肯定会发生一些不好的事情。

如果必须将二进制数据视为字符串,则应该应用可以处理二进制数据并可靠地生成可用字符串的转换。一个例子是base64编码。

在您的问题中,您似乎期望未加密的文本与转换为字符串的加密字节的长度相同。没有理由这样做。

如果你加密然后解密你收到原始邮件的加密字节,你应该期望。但是,加密数据的大小几乎肯定不会是相同的大小。