jac*_*nad 65 java security cryptography jce
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);
}
}
}
Run Code Online (Sandbox Code Playgroud)
Gar*_*ero 112
我不是很熟悉Android SDK,但似乎android-sdk自带的BouncyCastle已经添加到安全提供商.
在PC环境中你需要做的就是手动添加它,
Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());
Run Code Online (Sandbox Code Playgroud)
如果您有权访问该policy文件,只需添加如下条目:
security.provider.5=org.bouncycastle.jce.provider.BouncyCastleProvider
Run Code Online (Sandbox Code Playgroud)
请注意,.5它等于已添加的提供程序的序列号.
kap*_*das 13
您可以通过添加security.provider.编辑java.security来添加安全提供程序.= org.bouncycastle.jce.provider.BouncyCastleProvider
或者在班级的顶部添加一行
Security.addProvider(new BouncyCastleProvider());
Run Code Online (Sandbox Code Playgroud)
您可以在指定算法时使用以下行指定提供程序
Cipher cipher = Cipher.getInstance("AES", "SunJCE");
Run Code Online (Sandbox Code Playgroud)
如果你正在使用像Bouncy Castle这样的其他提供商
Cipher cipher = Cipher.getInstance("AES", "BC");
Run Code Online (Sandbox Code Playgroud)
Kru*_*tik 10
您可以通过使用以下代码编辑java.security来创建静态块来添加安全提供程序:
static {
Security.addProvider(new BouncyCastleProvider());
}
Run Code Online (Sandbox Code Playgroud)
如果您正在使用maven项目,则必须在项目的pom.xml文件中为BouncyCastleProvider添加依赖项,如下所示.
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcprov-jdk15on</artifactId>
<version>1.47</version>
</dependency>
Run Code Online (Sandbox Code Playgroud)
如果您使用的是普通的java项目,那么您可以从下面给出的链接添加下载bcprov-jdk15on-147.jar并编辑您的类路径.
http://www.java2s.com/Code/Jar/b/Downloadbcprovextjdk15on147jar.htm
| 归档时间: |
|
| 查看次数: |
105982 次 |
| 最近记录: |