Ada*_*fin 5 java inputstream ssl-certificate
在我的应用程序中,当与我正在使用的 API 通信时,我使用 p12 证书文件来加密流量。
对于我的生产环境,我需要从系统而不是从应用程序读取这些文件。
在 Linux 上,我如何将这些文件从系统中读取到应用程序中的 InputStream 中,就像从应用程序中的资源目录中读取一样?
我正在使用Java。
我构建了一个快速而肮脏的小类来显示我使用 .pfx 创建的相对 .pfx (P12) 的打开keytools。当然,如果有几个可能的位置,您也可以浏览不同的潜在目录来查找该文件。
文件结构如下所示:
./bin
./bin/Test.java
./bin/Test.class
./conf
./conf/myFile.pfx
Run Code Online (Sandbox Code Playgroud)
这是测试代码:
import java.io.*;
import java.security.*;
class Test {
public static void main(String[] args) {
String pass = "password";
try {
File file = new File("../conf/myFile.pfx");
InputStream stream = new FileInputStream(file);
KeyStore store = KeyStore.getInstance("PKCS12");
store.load(stream, pass.toCharArray());
PrivateKey key = (PrivateKey)store.getKey("example", pass.toCharArray());
System.out.println("Success");
} catch (KeyStoreException kse) {
System.err.println("Error getting the key");
} catch (Exception e) {
System.err.println("Error opening the key file");
e.printStackTrace();
}
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
17255 次 |
| 最近记录: |