Как перевести CryptoJS AES в код Java

Я хочу перевести код CryptoJS в код Java. Это код JavaScript:

CryptoJS.AES.encrypt('hello',CryptoJS.enc.Utf8.parse(CryptoJS.MD5("http://stackoverflow.com")), {iv: CryptoJS.enc.Utf8.parse("1234567812345678")})

Над строкой, вызывающей результат кода, находится «QtzDsbCgmA9+XBVEsEm70w==»

Затем я получаю значение ключа методом CryptoJS.MD5("http://stackoverflow.com").toString()(key = 57f4dad48e7a4f7cd171c654226feb5a)

Это код Java:

 try {
        String content = "hello";
        String key = "57f4dad48e7a4f7cd171c654226feb5a";
        KeyGenerator kgen = KeyGenerator.getInstance("AES");
        kgen.init(128, new SecureRandom(key.getBytes("utf-8")));
        SecretKey secretKey = kgen.generateKey();
        byte[] enCodeFormat = secretKey.getEncoded();


        SecretKeySpec key1 = new SecretKeySpec(enCodeFormat, "AES");

        Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");

        byte[] byteContent = content.getBytes("utf-8");


        cipher.init(Cipher.ENCRYPT_MODE, key1,new IvParameterSpec("1234567812345678".getBytes("UTF-8")));

        byte[] result = cipher.doFinal(byteContent);
        System.out.println(new String(result).equals("QtzDsbCgmA9+XBVEsEm70w=="));

    } catch (NoSuchAlgorithmException | NoSuchPaddingException e) {
        e.printStackTrace();
    } catch (BadPaddingException e) {
        e.printStackTrace();
    } catch (IllegalBlockSizeException e) {
        e.printStackTrace();
    } catch (InvalidKeyException e) {
        e.printStackTrace();
    } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
    } catch (InvalidAlgorithmParameterException e) {
        e.printStackTrace();
    }

но результат вывода ложный. Как исправить код Java, чтобы изменить результат на истинный.


person Sim Tom    schedule 14.03.2017    source источник
comment
Ну... Вы не кодируете байты в base64 перед их сравнением?   -  person Luke Joshua Park    schedule 14.03.2017
comment
Ну... CryptoJS.enc.Utf8.parse(CryptoJS.MD5("http://stackoverflow.com")) - это несоответствие типов. Может произойти все, что угодно. Вы либо хотите CryptoJS.enc.Utf8.parse(CryptoJS.MD5("http://stackoverflow.com").toString()), либо просто CryptoJS.MD5("http://stackoverflow.com"). Что он?   -  person Artjom B.    schedule 14.03.2017


Ответы (1)


Согласно совету @Luka Park, я решил свой вопрос. Это мое решение:

    Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
    byte[] raw = sKey.getBytes();
    SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
    IvParameterSpec iv = new IvParameterSpec(ivParameter.getBytes());
    cipher.init(Cipher.ENCRYPT_MODE, skeySpec, iv);
    byte[] encrypted = cipher.doFinal(sSrc.getBytes("utf-8"));
    return new BASE64Encoder().encode(encrypted);
person Sim Tom    schedule 16.03.2017