Public Key Infrastructure
Public Key Infrastructure
Public Key Infrastructure
INTRODUCTION:
A public key infrastructure (PKI) is a set of hardware, software,
people, policies, and procedures needed to create, manage, distribute, use,
store, and revoke digital certificates.
In cryptography, a PKI is an arrangement that binds public keys with
respective user identities by means of a certificate authority (CA). The user
identity must be unique within each CA domain. The third-party validation
authority (VA) can provide this information on behalf of the CA. The
binding is established through the registration and issuance process.
Depending on the assurance level of the binding, this may be carried out by
software at a CA or under human supervision. The PKI role that assures this
binding is called the registration authority (RA). The RA ensures that the
public key is bound to the individual to which it is assigned in a way that
ensures non-repudiation.
DESIGN:
Public key cryptography is a cryptographic technique that enables
users to securely communicate on an insecure public network, and reliably
verify the identity of a user via digital signatures.
A public key infrastructure (PKI) is a system for the creation, storage,
and distribution of digital certificates which are used to verify that a
particular public key belongs to a certain entity. The PKI creates digital
certificates which map public keys to entities, securely stores these
certificates in a central repository and revokes them if needed.
A PKI consists of:
A certificate authority (CA) that both issues and verifies the digital
certificates.
A certificate policy.
METHODS OF CERTIFICATION:
Broadly speaking, there have traditionally been three approaches to getting
this trust: certificate authorities (CAs), web of trust (WoT), and simple
public key infrastructure (SPKI).[citation needed]
Certificate authorities:
The primary role of the CA is to digitally sign and publish the public
key bound to a given user. This is done using the CA's own private key, so
that trust in the user key relies on one's trust in the validity of the CA's key.
When the CA is a third party separate from the user and the system, then it is
called the Registration Authority (RA), which may or may not be separate
from the CA. The key-user binding is established, depending on the level of
assurance the binding has, by software or under human supervision.
The term trusted third party (TTP) may also be used for certificate
authority (CA). Moreover, PKI is itself often used as a synonym for a CA
implementation.
Issuer Market Share:
A W3Techs survey from February 2015 shows:
Rank Issuer
Usage
market share
1.
Comodo
6.6%
33.6%
2.
33.2%
3.
13.2%
4.
GlobalSign
11.3%
2.2%
5.
DigiCert
0.6%
2.9%
WEB OF TRUST:
An alternative approach to the problem of public authentication of
public key information is the web-of-trust scheme, which uses self-signed
certificates and third party attestations of those certificates. The singular
term "web of trust" does not imply the existence of a single web of trust, or
common point of trust, but rather one of any number of potentially disjoint
"webs of trust".
One of the benefits of the web of trust, such as in PGP, is that it can
interoperate with a PKI CA fully trusted by all parties in a domain (such as
an internal CA in a company) that is willing to guarantee certificates, as a
trusted introducer. If the "web of trust" is completely trusted then, because of
the nature of a web of trust, trusting one certificate is granting trust to all the
certificates in that web.
Simple public key infrastructure:
Another alternative, which does not deal with public authentication of public
key information, is the simple public key infrastructure (SPKI) that grew out
of three independent efforts to overcome the complexities of X.509 and
PGP's web of trust. SPKI does not associate users with persons, since the
key is what is trusted, rather than the person. SPKI does not use any notion
of trust, as the verifier is also the issuer. This is called an "authorization
loop" in SPKI terminology, where authorization is integral to its design.
Blockchain-based PKI:
An emerging approach for PKI is to use the blockchain technology
commonly associated with modern cryptocurrency. Since blockchain
technology aims to provide a distributed and unalterable ledger of
information, it has qualities considered highly suitable for the storage and
management of public keys. EmerCoin is an example of a blockchain-based
cryptocurrency that supports the storage of different public key types (SSH,
GPG, RFC 2230, etc) and provides open source software that directly
supports PKI for OpenSSH servers.
USES:
PKIs of one type or another, and from any of several vendors, have many
uses, including providing public keys and bindings to user identities which
are used for: