我正在尝试使用byte []生成密钥,即从字符串生成密钥。 我的班级是最终的,我的方法是静态的。
类别:
public final class Operation {
public static Key getKey(byte[] arr)
{
Key key = null;
KeyGenerator keyGen;
Security.addProvider(new BouncyCastleProvider());
try
{
keyGen = KeyGenerator.getInstance("AES", "BC");
if(arr == null)
keyGen.init(192);
else
keyGen.init(new SecureRandom(arr));
key = keyGen.generateKey();
}
catch (NoSuchAlgorithmException e)
{
System.err.println(e);
} catch (NoSuchProviderException e) {
System.err.println(e);
}
return key;
}
public static String getKeyAsString(Key key)
{
return new String(Base64.encode(key.getEncoded()));
}
public static Key getKeyFromString(String string)
{
return new SecretKeySpec(Base64.decode(string.getBytes()), "AES");
}
}
主要功能有以下几行:
Key key1 = Operation.getKey("admin".getBytes());
Key key2 = Operation.getKey("admin".getBytes());
System.out.println(new String(Base64.encode(key1.getEncoded())));
System.out.println(new String(Base64.encode(key2.getEncoded())));
我在Windows上获得相同的键输出,如:
4BjJkLCJ3LyPluKkd2DBgqghhNfSgzKD
4BjJkLCJ3LyPluKkd2DBgqghhNfSgzKD
但Mac OS并非如此。
我使用的依赖是:
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcprov-jdk16</artifactId>
<version>1.46</version>
</dependency>
现在我发现JDK版本是唯一的问题。
在Windows上我有JDK 1.7
而我在MAC上有JDK 1.6
。
这真的是一个JDK问题因为我真的被困在这里。
请帮忙。
答案 0 :(得分:1)
我在Linux中看到了不同的价值观。我认为原因是SecureRandom
,请查看:
System.out.println(new SecureRandom("admin".getBytes()).nextLong());
System.out.println(new SecureRandom("admin".getBytes()).nextLong());
示例输出(每次更改):
1642139269925848082
2081201540941864354
来自javadoc:
许多SecureRandom实现采用伪随机的形式 数字生成器(PRNG),这意味着它们使用确定性 算法从真随机种子产生伪随机序列。 其他实现可能产生真正的随机数,还有其他实现 可以结合使用这两种技术。