KeyStore.load 在空的 .jks 文件上抛出 IOException

KeyStore.load throwing IOException on empty .jks file

我需要创建一个空的 KeyStore 文件(名为 KeyStoreAES.jks),然后将 AES SecretKey 存储到该文件中,所有这些都以编程方式来自 Java。

我有创建 .jks 文件的函数:

//Función that creates KeyStoreAES.jks
private static void CreateKeyStoreAES(String path)
{
    try
    {
        //Check if file already exists
        File keyStoreFile = new File(path);

        if (keyStoreFile.exists())
        {
            keyStoreFile.delete();
        } //if

        keyStoreFile.createNewFile();
    } 
    catch (IOException ex)
    {
        System.out.println("IOException");
    }
} //CrearKeyStoreAES

这个功能很好用。然后我有另一个函数可以将密钥插入该文件:

//Storing Key into KeyStore file
private static void StoreKey(String path, SecretKey key)
{
    try
    {       
        //KeyStore
        KeyStore ks = KeyStore.getInstance("JKS"); //JCEKS, JKS

        //FileInputStream
        FileInputStream fis = new FileInputStream(path);

        //Load KeyStore file
        ks.load(fis, keyStorePass);
    } 
    catch (CertificateException ex)
    {
        System.out.println("CertificateException");
    }
    catch (IOException ex)
    {
        System.out.println("IOException");
    }
    catch (KeyStoreException ex)
    {
        System.out.println("KeyStoreException");
    } 
    catch (NoSuchAlgorithmException ex)
    {
        System.out.println("NoSuchAlgorithmException");
    } //try
} //StoreKey

从 KeyStore 调用加载函数 class 抛出 IOException。这是因为试图加载的文件是空的吗?据我在 Internet 上搜索,要将密钥插入 KeyStore,您需要将该文件加载到 KeyStore 对象中。

是的,JKS 格式需要 header 和尾部信息,因此空文件不是有效的 JKS,没有条目的 JKS 不是空文件。

要创建 JKS 'from scratch',不要加载 任何 file/data:

KeyStore ks = KeyStore.getInstance("JKS");
ks.load(null); // NO INPUTSTREAM HERE
...
ks.setKeyEntry(...); // or .setEntry(...) as desired
...
OutputStream fo = Files.newOutputStream(Path.of("myfile")); // or similar
ks.store(fo,password); fo.close();

但是,JKS 格式不支持 SecretKey 条目,所以这仍然不能解决您的问题。您需要使用其他格式,如 JCEKS 或 PKCS12,或 BouncyCastle 的 BKS——所有这些格式也不能有效地成为空文件。