正在将密钥保存到derby数据集



我正在使用blowfish算法来加密图像和解密图像。我的程序运行起来没有任何问题,但我正在尝试对其进行小的修改。目前生成的密钥只是暂时保存在密钥变量中,但我想将其永久保存到derby数据库中,以便将来使用。

我的问题是在derby中,列应该是什么类型的数据才能保存密钥?(即:-大整数、varchar等)我可以直接保存到数据库吗?

谢谢。

下面是我生成密钥的代码。

public FunctionClass() {  
         try {  
            keyGenerator = KeyGenerator.getInstance("Blowfish");  
            secretKey = keyGenerator.generateKey();  
           cipher = Cipher.getInstance("Blowfish");  
        } catch (NoSuchPaddingException ex) {  
           System.out.println(ex);  
        } catch (NoSuchAlgorithmException ex) {  
            System.out.println(ex);  
       }  
}

您可以将密钥编码为字符串,并使用适当的数据类型(如Varchar )存储字符串

String encodedKey = Base64.getEncoder().encodeToString(secretKey.getEncoded());

密钥可以重建如下:

// decode the base64 encoded string
byte[] decodedKey = Base64.getDecoder().decode(encodedKey);
// rebuild key using SecretKeySpec
SecretKey originalKey = new SecretKeySpec(decodedKey, 0, decodedKey.length, keyGenerator.getAlgorithm()); 

最新更新