new icon example borderfactory java security cryptography jce

example - my icon java



Por quĂ© java.security.NoSuchProviderException NingĂșn proveedor: BC? (4)

No estoy muy familiarizado con el sdk de Android, pero parece que el android-sdk viene con el proveedor BouncyCastle ya agregado a la seguridad.

Lo que tendrá que hacer en el entorno de PC es simplemente agregarlo manualmente,

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

si tiene acceso al archivo de policy , simplemente agregue una entrada como:

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

Observe que .5 es igual a un número secuencial de los proveedores ya agregados.

Se ha agregado el jar (bcprov-jdk16-145.jar) al proyecto, Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider()) se ha agregado a la clase y BouncyCastleProvider.PROVIDER_NAME devuelve "BC "pero AesFileIo.writeFile () todavía arroja java.security.NoSuchProviderException No such provider: BC . ¿Algunas ideas?

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); } } }


Para aquellos que están usando servidores web, asegúrese de que bcprov-jdk16-145.jar se haya instalado en su servidor lib, ya que weblogic tuvo que poner el jar en:

<weblogic_jdk_home>/jre/lib/ext


Puede agregar el proveedor de seguridad editando java.security con el uso del siguiente código para crear un bloque estático:

static { Security.addProvider(new BouncyCastleProvider()); }

Si está utilizando el proyecto maven , tendrá que agregar la dependencia de BouncyCastleProvider de la siguiente manera en el archivo pom.xml de su proyecto.

<dependency> <groupId>org.bouncycastle</groupId> <artifactId>bcprov-jdk15on</artifactId> <version>1.47</version> </dependency>

Si está utilizando un proyecto Java normal , puede agregar la descarga bcprov-jdk15on-147.jar desde el siguiente enlace y editar su classpath.

http://www.java2s.com/Code/Jar/b/Downloadbcprovextjdk15on147jar.htm


puede agregar un proveedor de seguridad editando java.security agregando security.provider. = org.bouncycastle.jce.provider.BouncyCastleProvider

o agrega una línea en tu parte superior de tu clase

Security.addProvider(new BouncyCastleProvider());

puede usar la línea inferior para especificar el proveedor mientras especifica los algoritmos

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

si está usando otro proveedor como Bouncy Castle, entonces

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