Не могу создать шифр, нет такого алгоритма

Я использую BountyCastle зашифровать файл с помощью алгоритма AES128_CBC со следующим кодом:

static {
    Provider provider = Security.getProvider (BouncyCastleProvider.PROVIDER_NAME);
    if (provider == null) {
        Security.addProvider (new BouncyCastleProvider ());
    }
}

public static void main (String[] args) throws  IOException, CertificateException, UnrecoverableKeyException, KeyStoreException,
                                                NoSuchAlgorithmException, InvalidAlgorithmParameterException, NoSuchProviderException, 
                                                CertStoreException, CMSException, NoSuchPaddingException, InvalidKeyException, 
                                                ShortBufferException, IllegalBlockSizeException, BadPaddingException {

    File f             = new File ("ToBeEncrypted.txt");
    byte[] buffer      = new byte [(int)f.length ()];
    DataInputStream in = new DataInputStream (new FileInputStream (f));
    in.readFully (buffer);
    in.close ();

    X509Certificate cert = ReadX509.read (new FileInputStream ("test.cer"));

    CMSEnvelopedDataGenerator gen = new CMSEnvelopedDataGenerator ();
    RecipientInfoGenerator recipientGenerator = new JceKeyTransRecipientInfoGenerator (cert).setProvider ("BC");
    gen.addRecipientInfoGenerator (recipientGenerator);

    OutputEncryptor outputEncryptor = new JceCMSContentEncryptorBuilder (CMSAlgorithm.AES128_CBC).build ();
    CMSEnvelopedData envData        = gen.generate (new CMSProcessableByteArray (buffer), outputEncryptor);

    byte[] pkcs7envelopedData = envData.getEncoded ();

    FileOutputStream envfos   = new FileOutputStream ("ToBeDecrypted.pk7");
    envfos.write (pkcs7envelopedData);
    envfos.close ();
}

Тем не менее, я продолжаю иметь следующее исключение на линии

CMSEnvelopedData envData = gen.generate (new CMSProcessableByteArray (buffer), outputEncryptor);:

Exception in thread "main" org.bouncycastle.cms.CMSException: exception wrapping content key: cannot create cipher: No such algorithm: 1.2.840.10040.4.1
    at org.bouncycastle.cms.KeyTransRecipientInfoGenerator.generate(Unknown Source)
    at org.bouncycastle.cms.CMSEnvelopedDataGenerator.doGenerate(Unknown Source)
    at org.bouncycastle.cms.CMSEnvelopedDataGenerator.generate(Unknown Source)
    at com.crypto.tests.EncryptDocument.main(EncryptDocument.java:74)

Caused by: org.bouncycastle.operator.OperatorCreationException: cannot create cipher: No such algorithm: 1.2.840.10040.4.1
    at org.bouncycastle.operator.jcajce.OperatorHelper.createAsymmetricWrapper(Unknown Source)
    at org.bouncycastle.operator.jcajce.JceAsymmetricKeyWrapper.generateWrappedKey(Unknown Source)
... 4 more

Caused by: java.security.NoSuchAlgorithmException: No such algorithm: 1.2.840.10040.4.1
    at javax.crypto.Cipher.getInstance(Cipher.java:688)
    at javax.crypto.Cipher.getInstance(Cipher.java:596)
    at org.bouncycastle.jcajce.util.NamedJcaJceHelper.createCipher(Unknown Source)
    ... 6 more

Любая идея?

1 ответ

Решение

Вы не можете зашифровать с помощью алгоритма DSA или ключа DSA (1.2.840.10040.4.1 - это DSA). DSA обозначает алгоритм цифровой подписи. Попробуйте вместо этого использовать RSA.

Другие вопросы по тегам