使用byte []生成密钥会为MAC和Windows生成不同的结果

时间:2014-02-20 07:26:54

标签: java windows macos encryption bouncycastle

我正在尝试使用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问题因为我真的被困在这里。

请帮忙。

1 个答案:

答案 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),这意味着它们使用确定性   算法从真随机种子产生伪随机序列。   其他实现可能产生真正的随机数,还有其他实现   可以结合使用这两种技术。