Задать вопрос
@DS1977

Golang cipher AES decrypt. Как раскодировать string закодированный на Java?

Имеется String закодированный на Java:
Java
private static final String ALGO = "AES"

    public static String encrypt(String data, String secretKey) throws EKCryptException {
        try {
            Key key = generateKey(secretKey);
            Cipher c = Cipher.getInstance(ALGO);
            c.init(Cipher.ENCRYPT_MODE, key);
            byte[] encVal = c.doFinal(data.getBytes());
            byte[] encoded = Base64.getEncoder().encode(encVal);
            return new String(encoded, "UTF8");
        } catch(Exception ex) {
            log.error("Failure occured while encrypt text value!", ex);
            throw new EKCryptException(data, ex);
        }
    }

    private static Key generateKey(String keyValue) throws EKCryptException {
        try {
            byte[] decodedKey = Base64.getDecoder().decode(keyValue);
            SecretKey originalKey = new SecretKeySpec(decodedKey, 0, decodedKey.length, ALGO); 
            return originalKey;
        } catch(Exception ex) {
            log.error("Failure occured while generate key!", ex);
            throw new EKCryptException("Failure occured while generate key!", ex);
        }
    }



Как расшифровать на Go. Мои попытки выдают: cipher: message authentication failed
Go
func decode(data string) (string, error)  {
	ciphertext := []byte(data)
	c, err := aes.NewCipher([]byte(DECODE_KEY))
	if err != nil {
		return "", err
	}

	gcm, err := cipher.NewGCMWithNonceSize(c, 0)
	if err != nil {
		return "", err
	}

	nonceSize := 0
	if len(ciphertext) < nonceSize {
		return  "", errors.New("ciphertext too short")
	}

	nonce, ciphertext := ciphertext[:nonceSize], ciphertext[nonceSize:]
	result, err := gcm.Open(nil, nonce, ciphertext, nil)
	if err != nil {
		return "", err
	}
	return string(result), nil
}



Key естественно тот же
  • Вопрос задан
  • 786 просмотров
Подписаться 1 Средний Комментировать
Решения вопроса 1
@DS1977 Автор вопроса
Мое решение

Java
public static String encryptGCM(String data) throws CryptException {
    try {
        SecureRandom random = SecureRandom.getInstanceStrong();
        byte[] iv = new byte[12];
        random.nextBytes(iv);
        log.trace("IV: {}", Arrays.toString(iv));
        Key key = generateGcmKey();
        Cipher cipher = Cipher.getInstance("AES/GCM/NoPadding");
        GCMParameterSpec spec = new GCMParameterSpec(128, iv);
        cipher.init(Cipher.ENCRYPT_MODE, key, spec);
        byte[] cipherText = cipher.doFinal(data.getBytes("UTF-8"));
        log.trace("encrypted: {}", Arrays.toString(cipherText));
        byte[] result = new byte[cipherText.length + iv.length];
        System.arraycopy(iv, 0, result, 0, iv.length);
        System.arraycopy(cipherText, 0, result, iv.length, cipherText.length);
        log.trace("Not encoded result: {}", Arrays.toString(result));
        return Base64.getEncoder().encodeToString(result);
    } catch (Exception ex) {
        log.error("Failure occured while encrypt text value!", ex);
        throw new CryptException(data, ex);
    }
}

private static Key generateGcmKey() throws CryptException {
    try {
        SecretKey originalKey = new SecretKeySpec(KEY.getBytes(), 0, KEY.getBytes().length, ALGO);
        log.trace("Encoded key: {}", Base64.getEncoder().encodeToString(originalKey.getEncoded()));
        return originalKey;
    } catch (Exception ex) {
        log.error("Failure occured while generate key!", ex);
        throw new CryptException("Failure occured while generate key!", ex);
    }
}

GO
func decode(data string) (string, error) {
  ciphertext, _ := base64.StdEncoding.DecodeString(data)
  key, _ := base64.URLEncoding.DecodeString(decodeKey)
  c, err := aes.NewCipher([]byte(key))
  if err != nil {
    return "", err
  }

  gcm, err := cipher.NewGCM(c)
  if err != nil {
    return "", err
  }

   nonceSize := 12
   if len(ciphertext) < nonceSize {
     return  "", errors.New("ciphertext too short")
   }

   nonce, ciphertext := ciphertext[:nonceSize], ciphertext[nonceSize:]

   result, err := gcm.Open(nil, nonce, ciphertext, nil)
   if err != nil {
     return "", err
   }
   return string(result), nil
 }

Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы