Пары ключей EC полностью несовместимы с RSA.
Для этих конкретных кривых существует только один тип ключа EC (хотя при кодировании существуют разные представления одной и той же точки).Единицы для ECDH (ключевое соглашение) / ECIES и ECDSA также совпадают.
То есть , если генерируется ключ EC для генератора пар ключей "RSA"
, вы можете быть уверены, что он идентичен тому, который сгенерирован для ключа "EC"
.Просто протестируйте, выполнив генерацию / проверку подписи EC или - чуть более сложное - соглашение о ключе.
Вы можете протестировать, создав собственную детерминированную SecureRandom
реализацию и требуя ECреализация, чтобы использовать это.Это также связано с тем, что при генерации пары ключей EC не так много вариантов, как при генерации пары ключей RSA, поэтому реализации алгоритма, вероятно, будут такими же.Поэтому, если вы начнете с одинаковых значений, вполне вероятно, что он генерирует идентичные пары ключей.Затем вы можете сравнить значения открытых ключей или использовать один открытый ключ для проверки подписи из другого закрытого ключа.
Возможно, базовая реализация игнорирует SecureRandom
, как указано, если хранилище ключей Android не может с этим справиться.
Хотя у меня нет этих версий Android здесь.
Обратите внимание, что данный метод генерации ключа EC может рассматриваться как взлом.А поскольку Android 5 / API 22 существует 5 лет назад, вы можете спросить себя, хотите ли вы по-прежнему поддерживать эти версии.
В качестве альтернативы вы можете полностью сгенерировать пары ключей EC в программном обеспечении с использованием Bouncy Castle, но AndroidВ этом случае хранилище ключей не используется для защиты ключей.