在Java中从私有获取公钥
作者:互联网
我记得很久以前用OpenSSL这么做了,但我想知道它是否可能以及如何,我从来没有在java上使用过Cryptography.
解决方法:
您无法直接从另一个生成任一密钥.这在数学上是不可能的.如果你有一个包含公钥和私钥的密钥blob,你可以相对容易地提取其中一个.
2017年编辑:很多年以后对加密的理解要好得多,现在我很清楚这个答案并不是真的正确.
引用维基百科:
The public key consists of the modulus n and the public (or encryption) exponent e. The private key consists of the modulus n and the private (or decryption) exponent d, which must be kept secret. p, q, and λ(n) must also be kept secret because they can be used to calculate d.
公共模数n可以计算为p×q.原始私钥中唯一缺少的是e,但是这个值通常被选为65537,如果不是,你仍然可以从d和λ(n)计算e.
但是,许多私钥存储格式实际上包含公共模数n和其他组件,因此您可以直接提取值.
编辑,2018年:仍然为此投票,这是正确的!我将这个答案留下来,这样人们就能明白为什么我本来就错了,并提醒自己将来不要错.
标签:private-key,java,public-key 来源: https://codeday.me/bug/20191007/1869064.html