Java-эквивалент метода Convert.FromBase64String

Существует ли некоторый эквивалент Java для Convert.FromBase64String, который

Преобразует указанную строку, которая кодирует двоичные данные в виде цифр с основанием 64, в эквивалентный массив 8-битных целых чисел без знака.

Я пытался:

Будем признательны за любые предложения!


person Maksym Gontar    schedule 16.02.2010    source источник
comment
Я отказываюсь давать ссылку на apache commons-codec более одного раза в день.   -  person Bozho    schedule 16.02.2010
comment
java не имеет беззнаковых типов, кстати   -  person Bozho    schedule 16.02.2010
comment
правильно, но мне нужно иметь те же значения, что и в С# или что-то еще (означает int 255 вместо байта -1)   -  person Maksym Gontar    schedule 17.02.2010


Ответы (2)


В общем, велики шансы, что если в стандартных библиотеках Java нет того, что вам нужно, то это есть в среде Apache Commons. В этом случае вам понадобится decodeBase64 из commons.codec.binary.Base64.

person John Feminella    schedule 16.02.2010
comment
спасибо, я пробовал как методы декодирования, так и методы кодирования, но все равно это не беззнаковые 8-битные данные, полученные в результате... - person Maksym Gontar; 16.02.2010
comment
Я не думаю, что это правильно. Вывод decodeBase64 — byte[]. - person John Feminella; 16.02.2010
comment
принято, мне действительно пришлось использовать метод ‹i›decode‹/i› вместо кодирования (запутанный описанием msdn...) и добавить маску & 0xff, чтобы иметь эквивалентное значение без знака. В таком случае значения в С# и java точно такие же. - person Maksym Gontar; 17.02.2010

Ключ и исходный вектор преобразуются с использованием шифрования Convert.FromBase64String вAES в C#.

В java вы можете использовать метод DatatypeConverter.parseBase64Binary(string). Чтобы использовать его, импортируйте import javax.xml.bind.*;

Вот пример программы

import java.util.Base64;

import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import javax.xml.bind.*;

class AESEncryption {

    private static final String key = "type your key here.(base64)";
    private static final String initVector = "type your initial vector here.(base64)";

    static byte[] encodedKey = DatatypeConverter.parseBase64Binary(key);
    static byte[] encodedIV = DatatypeConverter.parseBase64Binary(initVector);

    public static String encrypt(final String value) {
        try {
            IvParameterSpec iv = new IvParameterSpec(encodedIV);
            SecretKeySpec skeySpec = new SecretKeySpec(encodedKey, "AES");

            Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5PADDING");
            cipher.init(Cipher.ENCRYPT_MODE, skeySpec, iv);

            byte[] encrypted = cipher.doFinal(value.getBytes());

            return Base64.getEncoder().encodeToString(encrypted);

        } catch (final Exception ex) {
            ex.printStackTrace();
        }
        return null;
    }

    public static String decrypt(final String encrypted) {
        try {
            IvParameterSpec iv = new IvParameterSpec(encodedIV);
            SecretKeySpec skeySpec = new SecretKeySpec(encodedKey, "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 (final Exception ex) {
            ex.printStackTrace();
        }

        return null;
    }

    public static void main(final String[] args) {

        String originalString = "Here is your text to be encrypted.";
        System.out.println("Original String to encrypt - " + originalString);

        String encryptedString = encrypt(originalString);
        System.out.println("Encrypted String - " + encryptedString);

        String decryptedString = decrypt(encryptedString);
        System.out.println("After decryption - " + decryptedString);
    }
}
person Sevitha Heshan    schedule 03.04.2020