Как создать открытый ключ для криптосистемы 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,

Другие вопросы по тегам