Public Key Infrastructure (PKI)

By Khanh Pham

Overview

PKI is the security infrastructure which provides all necessary services to implement public-key cryptography on open networks and thus enables secure communication using public-key cryptography on those networks.

Main concepts

Public-key cryptography

The main idea of public-key cryptography is to use different keys for encryption and decryption. The encryption key is made public and thus also called public key, while the decryption key is kept private and thus also called private key.

Two important requirements on public-key cryptography are:

  1. The encryption function must be a one-way function
  2. It is infeasible to derive one key from another.

Using public-key cryptography, the encrypted messages can only be decrypted by using the corresponding private keys. This prevents the man-in-the-middle attacks, as it is not possible for the interceptors to decrypt the messages unless they know the private keys. The main processing flow is as follows [1]:

public-key-cryptography

The first and most widely used public-key cryptosystem is RSA, which is named after its inventors Ron Rivest, Adi Shamir, and Leonard Adleman.

Digital signatures

Digital signatures are analogous to hand-written signatures in that they are used to prove the authenticity of a message.

The main idea is that the sender uses its private key (which is only known to the sender) to sign a message. Then, upon receiving the signed message, the receiver uses the sender’s public key to verify the authenticity and the integrity of the signed message. The basic process is as follows [2]:

digital-signature

It is important to note that the signature must always be associated with the message from which the signature is created. This is analogous to a hand-written signature must be associated with the content on which the signature was signed.

The most widely used digital signature is the RSA signature scheme.

Digital certificates

Digital certificates are used to prove the authenticity of public keys by binding public keys to their owners. Without certificates, public-key cryptography can easily be the victim of the man-in-the-middle attacks. For example, if Oscar somehow replaces Alice’s public key by his, then every messages encrypted with the compromised Alice’s public key can be decrypted by Oscar when he intercepts the messages.

In its simplest form, a certificate looks like this [2]:

simplest-cert

The certificate contains the signature which must be signed by a certificate authority. This signature guarantees the integrity of the certificate, which provides the information about the public key and its owner.

One commonly used certificate standard is X.509.

Certificate authority (CA)

Certificate authorities are trusted third-parties who are responsible for managing the certificates, e.g., issuing and revoking certificates.

Main services

The main services provided by PKI include:

  • Confidentiality
    • Data is protected from unauthorized entities.
    • By public key encryption and private key decryption
  • Data integrity
    • Data could not be changed by unauthorized entities.
    • By digital signatures
  • Authentication
    • Involved entities must prove who they are
    • By signing on authentication information
  • Data origin authenticity
    • The origin of the data must be reliable.
    • By digital certificates and signatures
  • Non-repudiation
    • Prevents involved entities from denying that they have performed some actions, e.g., some harmful actions.
    • By digital signatures

References

[1] Introduction to Public Key Infrastructures

[2] Understanding Cryptography: A Textbook for Students and Practitioners

[3] Understanding PKI: Concepts, Standards, and Deployment Considerations