Jar(bcprov-jdk16-145.jar)がプロジェクトに追加され、Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider())
がクラスに追加され、BouncyCastleProvider.PROVIDER_NAME
は「BC」を返しますが、AesFileIo.writeFile()は引き続きJava.security.NoSuchProviderException No such provider: BC
。何か案は?
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);
}
}
}
Android sdkにあまり慣れていませんが、Android-sdk
には、セキュリティに既に追加されているBouncyCastle
プロバイダーが付属しています。
PC環境で行う必要があるのは、手動で追加するだけです。
Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());
policy
ファイルにアクセスできる場合は、次のようなエントリを追加します。
security.provider.5=org.bouncycastle.jce.provider.BouncyCastleProvider
.5
これは、すでに追加されているプロバイダーの連続番号と同じです。
security.provider。= org.bouncycastle.jce.provider.BouncyCastleProviderを追加してJava.securityを編集することにより、セキュリティプロバイダーを追加できます。
または、クラスの最上部に行を追加します
Security.addProvider(new BouncyCastleProvider());
以下の行を使用して、アルゴリズムを指定しながらプロバイダーを指定できます
Cipher cipher = Cipher.getInstance("AES", "SunJCE");
bouncy Castleのような他のプロバイダーを使用している場合
Cipher cipher = Cipher.getInstance("AES", "BC");
次のコードを使用して静的ブロックを作成し、Java.securityを編集することにより、セキュリティプロバイダーを追加できます。
static {
Security.addProvider(new BouncyCastleProvider());
}
mavenプロジェクトを使用している場合の場合、プロジェクトのpom.xmlファイルに次のようにBouncyCastleProviderの依存関係を追加する必要があります。
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcprov-jdk15on</artifactId>
<version>1.47</version>
</dependency>
通常のJavaプロジェクトを使用している場合、ダウンロードを追加できますbcprov-jdk15on-147.jar以下のリンクから編集しますクラスパス。
http://www.Java2s.com/Code/Jar/b/Downloadbcprovextjdk15on147jar.htm
Webサーバーを使用している場合は、weblogicがjarを次の場所に配置する必要があるため、bcprov-jdk16-145.jarがサーバーlibにインストールされていることを確認してください。
<weblogic_jdk_home>\jre\lib\ext