84 votes

Pourquoi java.security.NoSuchProviderException Aucun fournisseur de ce type: BC?

Le fichier jar (bcprov-jdk16-145.jar) a été ajouté au projet, Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider()) a été ajouté à la classe et BouncyCastleProvider.PROVIDER_NAME renvoie "BC" mais AesFileIo.writeFile ( ) lance toujours java.security.NoSuchProviderException No such provider: BC . Des idées?

 import java.io.FileOutputStream;
import java.io.InputStreamReader;
import java.io.ObjectOutputStream;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import org.bouncycastle.jce.provider.BouncyCastleProvider;

public class AesFileIo {

    private static final String AES_ALGORITHM = "AES/CTR/NoPadding";
    private static final String PROVIDER = BouncyCastleProvider.PROVIDER_NAME;
    private static final byte[] AES_KEY_128 = { // Hard coded for now
        78, -90, 42, 70, -5, 20, -114, 103,
        -99, -25, 76, 95, -85, 94, 57, 54};
    private static final byte[] IV = { // Hard coded for now
        -85, -67, -5, 88, 28, 49, 49, 85,
        114, 83, -40, 119, -65, 91, 76, 108};
    private static final SecretKeySpec secretKeySpec =
            new SecretKeySpec(AES_KEY_128, "AES");
    private static final IvParameterSpec ivSpec = new IvParameterSpec(IV);

    public void AesFileIo() {
        Security.addProvider(new org.bouncycastle.jce.provider
                .BouncyCastleProvider());
    }

    public void writeFile(String fileName, String theFile) {
        try {
            Cipher cipher = Cipher.getInstance(AES_ALGORITHM, PROVIDER);
            cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec, ivSpec);
            byte[] encrypted = cipher.doFinal(theFile.getBytes());
            ObjectOutputStream os = new ObjectOutputStream(
                new FileOutputStream(fileName));
            os.write(encrypted);
            os.flush();
            os.close();
        } catch (Exception e) {
            StackTraceElement se = new Exception().getStackTrace()[0];
            System.err.println(se.getFileName() + " " + se.getLineNumber()
                    + " " + e);
        }
    }
}

139voto

Garis M Suero Points 4005

Je ne connais pas très bien le SDK Android, mais il semble que le android-sdk livré avec le BouncyCastle déjà ajouté à la sécurité.

Ce que vous devrez faire dans l'environnement PC est simplement de l'ajouter manuellement,

 Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());

si vous avez accès au policy , ajoutez simplement une entrée comme:

 security.provider.5=org.bouncycastle.jce.provider.BouncyCastleProvider 

Notez que le .5 est égal à un nombre séquentiel des fournisseurs déjà ajoutés.

16voto

kapil das Points 470

vous pouvez ajouter un fournisseur de sécurité en modifiant java.security en ajoutant security.provider. = org.bouncycastle.jce.provider.BouncyCastleProvider

ou ajoutez une ligne dans votre top de votre classe

 Security.addProvider(new BouncyCastleProvider());

vous pouvez utiliser la ligne ci-dessous pour spécifier le fournisseur tout en spécifiant des algorithmes

 Cipher cipher = Cipher.getInstance("AES", "SunJCE");

si vous utilisez un autre fournisseur comme Bouncy Castle, alors

 Cipher cipher =  Cipher.getInstance("AES", "BC");

2voto

Peter Isberg Points 329

Mon expérience avec ceci était que lorsque j'avais cela dans chaque exécution, c'était bien d'utiliser le fournisseur comme une chaîne comme celle-ci

 Security.addProvider(new BounctCastleProvider());
new JcaPEMKeyConverter().setProvider("BC");

Mais quand j'ai optimisé et mis ce qui suit dans le constructeur:

    if(bounctCastleProvider == null) {
      bounctCastleProvider = new BouncyCastleProvider();
    }

    if(Security.getProvider(bouncyCastleProvider.getName()) == null) {
      Security.addProvider(bouncyCastleProvider);
    }

Ensuite, j'ai dû utiliser un fournisseur comme celui-ci ou j'obtiendrais l'erreur ci-dessus:

 new JcaPEMKeyConverter().setProvider(bouncyCastleProvider);

J'utilise bcpkix-jdk15on version 1.65

1voto

mel3kings Points 1201

Pour ceux qui utilisent des serveurs Web, assurez-vous que le fichier bcprov-jdk16-145.jar a été installé dans la librairie de vos serveurs, car weblogic a dû mettre le fichier jar dans:

 <weblogic_jdk_home>\jre\lib\ext

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X