我正在使用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());