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 () jette 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);
}
}
}
Je ne connais pas très bien le Android sdk, mais il semble que le Android-sdk
vient avec le fournisseur BouncyCastle
déjà ajouté à la sécurité.
Ce que vous devrez faire dans l’environnement PC, c’est juste l’ajouter manuellement,
Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());
si vous avez accès au fichier policy
, ajoutez simplement une entrée comme celle-ci:
security.provider.5=org.bouncycastle.jce.provider.BouncyCastleProvider
Remarquez le .5
est égal à un nombre séquentiel des fournisseurs déjà ajoutés.
vous pouvez ajouter un fournisseur de sécurité en modifiant Java.security en ajoutant security.provider. = org.bouncycastle.jce.provider.BouncyCastleProvider
ou ajouter 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");
Vous pouvez ajouter un fournisseur de sécurité en modifiant Java.security en utilisant le code suivant pour créer un bloc statique:
static {
Security.addProvider(new BouncyCastleProvider());
}
Si vous utilisez le projet maven , vous devrez alors ajouter une dépendance pour BouncyCastleProvider comme suit dans le fichier pom.xml de votre projet.
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcprov-jdk15on</artifactId>
<version>1.47</version>
</dependency>
Si vous utilisez un projet normal Java project , vous pouvez ajouter le téléchargement bcprov -jdk15on-147.jar à partir du lien indiqué ci-dessous et modifiez votre chemin d'accès aux classes.
http://www.Java2s.com/Code/Jar/b/Downloadbcprovextjdk15on147jar.htm
Pour ceux qui utilisent des serveurs Web, assurez-vous que le fichier bcprov-jdk16-145.jar a été installé sur votre serveur lib, car weblogic a dû placer le fichier jar dans:
<weblogic_jdk_home>\jre\lib\ext