Как создать открытый ключ для криптосистемы Okamoto Uchiyama?
Я внедряю криптосистему Окамото Утияма в Java. Алгоритм здесь
Для открытого ключа значение параметра h рассчитывается как
h = g^n mod n
где,
g является корнем простого числа p (340 битов)
n = p^2 * q (1024bits)
Я использовал тип BigInteger для g, h и n. Когда я запускаю код, он не заканчивается. Вот код Подскажите пожалуйста как рассчитать ч.
import java.math.BigInteger;
import java.util.Random;
public class KeyPairGeneration {
PrimeGenerator PrimeGeneratorObject = new PrimeGenerator();
BigInteger PrivateFields[] = new BigInteger[2];
BigInteger PublicFields[] = new BigInteger[4];
BigInteger ONE = new BigInteger("1");
BigInteger DECREMENT = new BigInteger("-1");
/**
* Generate Private Key with two large primes
*/
public BigInteger[] PrivateKeyGenerator() {
PrivateFields[0] = PrimeGeneratorObject.RandomPrime(); // p
PrivateFields[1] = PrimeGeneratorObject.RandomPrime(); // q
if(PrivateFields[0] != PrivateFields[1])
return PrivateFields;
else
return PrivateKeyGenerator();
}
/**
* Generate Public Key from Private Key
*/
public BigInteger[] PublicKeyGenerator() {
PublicFields[0] = PrivateFields[0].multiply(PrivateFields[0]).multiply(PrivateFields[1]); // n = p*p*q
BigInteger g = new BigInteger("1");
Random randomGenerator = new Random();
for (int idx = 1; idx <= PrivateFields[0].intValue(); ++idx){
int randomInt = randomGenerator.nextInt(100);
if (primitiveRoot(randomInt, PrivateFields[0].intValue())) {
BigInteger primitiveRoot = new BigInteger(String.valueOf(randomInt));
PublicFields[1] = g.multiply(primitiveRoot); // g = primitive root of P
break;
}
}
int randomizationValue = randomGenerator.nextInt(100);
PublicFields[2] = BigInteger.valueOf(randomizationValue); // r < n
PublicFields[3] = PublicFields[1].modPow(PublicFields[0],PublicFields[0]); // h = g^n mod n
return PublicFields;
}
public static boolean primitiveRoot(int a, int p) {
int val = a, i;
// Calculate each modular exponent a^2, a^3... mod p.
for (i=2; i<p; i++) {
val = val*a%p;
if (val == 1)
break;
}
// If the exponent is p-1, it's a primitive root!
return (i == p-1);
}
}
1 ответ
Решение
p
не вписывается в int, так PrivateFields[0].intValue()
должно быть неправильно. Ваш primitiveRoot
алгоритм должен взять BigInteger
и не int
,