Sobes.tech
Назад к вопросам
Senior
7

Есть ли опыт с шифрованием/криптографией (AES-256)?

Компании, где спрашивали
АО Национальная система платежных карт

Ответ от нейросети

sobes.tech AI

Да, есть опыт работы с шифрованием AES-256 в Java. AES-256 — это симметричный алгоритм шифрования с длиной ключа 256 бит, обеспечивающий высокий уровень безопасности.

Пример использования AES-256 в Java с библиотекой javax.crypto:

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.GCMParameterSpec;
import java.util.Base64;

public class AES256Example {
    private static final int KEY_SIZE = 256;
    private static final int T_LEN = 128; // длина тега для GCM

    public static void main(String[] args) throws Exception {
        // Генерация ключа
        KeyGenerator keyGen = KeyGenerator.getInstance("AES");
        keyGen.init(KEY_SIZE);
        SecretKey key = keyGen.generateKey();

        // Инициализационный вектор (IV) для GCM
        byte[] iv = new byte[12]; // обычно 12 байт
        java.security.SecureRandom random = new java.security.SecureRandom();
        random.nextBytes(iv);

        String plaintext = "Пример текста для шифрования";

        // Шифрование
        Cipher cipher = Cipher.getInstance("AES/GCM/NoPadding");
        GCMParameterSpec spec = new GCMParameterSpec(T_LEN, iv);
        cipher.init(Cipher.ENCRYPT_MODE, key, spec);
        byte[] encrypted = cipher.doFinal(plaintext.getBytes());

        String encryptedBase64 = Base64.getEncoder().encodeToString(encrypted);
        System.out.println("Зашифрованный текст: " + encryptedBase64);

        // Расшифровка
        cipher.init(Cipher.DECRYPT_MODE, key, spec);
        byte[] decrypted = cipher.doFinal(encrypted);
        System.out.println("Расшифрованный текст: " + new String(decrypted));
    }
}

В этом примере используется режим AES-GCM, который обеспечивает как конфиденциальность, так и целостность данных. Важно правильно управлять ключами и IV для безопасности.