Initial bytes incorrect after Java AES/CBC decryption

前端 未结 10 2143
鱼传尺愫
鱼传尺愫 2020-11-22 12:47

What\'s wrong with the following example?

The problem is that the first part of the decrypted string is nonsense. However, the rest is fine, I get...

10条回答
  •  没有蜡笔的小新
    2020-11-22 13:24

    Online Editor Runnable version:-

    import javax.crypto.Cipher;
    import javax.crypto.spec.IvParameterSpec;
    import javax.crypto.spec.SecretKeySpec;
    //import org.apache.commons.codec.binary.Base64;
    import java.util.Base64;
    
    public class Encryptor {
        public static String encrypt(String key, String initVector, String value) {
            try {
                Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5PADDING");
                IvParameterSpec iv = new IvParameterSpec(initVector.getBytes("UTF-8"));
    
                SecretKeySpec skeySpec = new SecretKeySpec(key.getBytes("UTF-8"), "AES");
                cipher.init(Cipher.ENCRYPT_MODE, skeySpec, iv);
    
                byte[] encrypted = cipher.doFinal(value.getBytes());
    
                //System.out.println("encrypted string: "
                  //      + Base64.encodeBase64String(encrypted));
    
                //return Base64.encodeBase64String(encrypted);
                String s = new String(Base64.getEncoder().encode(encrypted));
                return s;
            } catch (Exception ex) {
                ex.printStackTrace();
            }
            return null;
        }
    
        public static String decrypt(String key, String initVector, String encrypted) {
            try {
                IvParameterSpec iv = new IvParameterSpec(initVector.getBytes("UTF-8"));
                SecretKeySpec skeySpec = new SecretKeySpec(key.getBytes("UTF-8"), "AES");
    
                Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5PADDING");
                cipher.init(Cipher.DECRYPT_MODE, skeySpec, iv);
    
                byte[] original = cipher.doFinal(Base64.getDecoder().decode(encrypted));
    
                return new String(original);
            } catch (Exception ex) {
                ex.printStackTrace();
            }
    
            return null;
        }
    
        public static void main(String[] args) {
            String key = "Bar12345Bar12345"; // 128 bit key
            String initVector = "RandomInitVector"; // 16 bytes IV
    
            System.out.println(encrypt(key, initVector, "Hello World"));
            System.out.println(decrypt(key, initVector, encrypt(key, initVector, "Hello World")));
        }
    }
    

提交回复
热议问题