Search code examples
cryptography

How are public and private keys different?


I have a follow up question to Given a private key, is it possible to derive it’s public key?

Are the public and the private keys the 'same' (in the sense that you just choose to make one public) or can you do more with the private key than with the public key?

EDIT - to better state my question:

When the two keys are generated, could I just randomly choose one of them to be the public key?


Solution

  • It really depends on what you call "private key." In almost every practical sitation, the sender knowing the private key also knows the public key. It provides others with its public key so it needs to know it. So in essence, that "private key" will contain "public key" information or at least it can be derived from it.

    Generally, you cannot swap private and public keys. In fact, they are not always of the same type (depending on the cryptosystem used). For instance, in ECDSA, your public key is a two-dimensional "point" on an elliptic curve, whereas your private key is a number.