我正在研究基于密码算法的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)
我应该为扩展的密钥大小输入什么号码?我在文档中看不到,这就是我在这里问的原因。
答案 0 :(得分:1)
Cryptonight使用修改后的AES算法。在标准算法中,您将256位密钥扩展为每个128位的15个密钥。对于cryptonight,您仅需要10个128位密钥。 所以输出长度应该是1280位或160字节
很好的文章,解释了Java代码示例的关键时间表(包括Cryptonight修改的AES算法的案例):
http://cryptoexplained.tech/hash-algorithms/aes-key-schedule
和代码源: