Java Cryptonight哈希算法 - 扩展AES密钥长度?

时间:2018-02-02 16:29:20

标签: java algorithm hash cryptography aes

我正在研究基于密码算法的Java加密货币挖掘器应用程序。

我正在尝试基于此文档实现散列函数:https://cryptonote.org/cns/cns008.txt

我的代码:

public byte[] mine(String hash) {
    byte[] out = hash.getBytes();
    out = doKeccak(out);

    //Make key
    byte[] key = new byte[32];
    System.arraycopy(out, 0, key, 0, 32);

    //Make blocks
    byte[][] blocks = new byte[8][];
    for (int i = 0; i < 8; ++i)
        System.arraycopy(out, 64 + 16 * i, blocks[i], 0, 16);

    byte[][] keys = new byte[11][];
    keys[0]=key;
    for (int i = 0; i < 10; ++i) {
        keys[i+1]=new byte[32];
        Rijndael.expandKey(keys[i], keys[i+1], 0, 32, 32);
    }

    //byte[] pad = new byte[2097152];

    //Encrypt blocks
    for (int bid = 0; bid < 8; ++bid) {
        for (int i = 0; i < 10; ++i) {
            blocks[bid] = AES.encrypt(blocks[i], keys[i+1]);
        }
    }

    return Utils.byteToHex(out);
}

Rijndael.expandKey方法的用法如下:public static void expandKey(byte[] key, byte[] out, int offset, int keySize, int expKeySize)

我应该为扩展的密钥大小输入什么号码?我在文档中看不到,这就是我在这里问的原因。

1 个答案:

答案 0 :(得分:1)

Cryptonight使用修改后的AES算法。在标准算法中,您将256位密钥扩展为每个128位的15个密钥。对于cryptonight,您仅需要10个128位密钥。 所以输出长度应该是1280位或160字节

很好的文章,解释了Java代码示例的关键时间表(包括Cryptonight修改的AES算法的案例):

http://cryptoexplained.tech/hash-algorithms/aes-key-schedule

和代码源:

https://github.com/cryptoexplained/hash-algorithms/blob/master/src/main/java/tech/cryptoexplained/hash/aes/Aes.java