mirror of
https://github.com/apache/httpd.git
synced 2025-06-03 10:42:03 +03:00
git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@96194 13f79535-47bb-0310-9956-ffa450edef68
692 lines
33 KiB
HTML
692 lines
33 KiB
HTML
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
|
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
|
|
<html xmlns="http://www.w3.org/1999/xhtml">
|
|
<head>
|
|
<title>Apache SSL/TLS Encryption: An Introduction</title>
|
|
<style type="text/css"><!--
|
|
#H {
|
|
}
|
|
#D {
|
|
background-color: #f0f0f0;
|
|
}
|
|
--></style>
|
|
</head>
|
|
|
|
<body bgcolor="#FFFFFF" text="#000000" link="#0000FF" vlink="#000080" alink="#FF0000">
|
|
<!--#include virtual="header.html" -->
|
|
|
|
<h1 align="center">SSL/TLS Strong Encryption: An Introduction</h1>
|
|
|
|
<div align="right">
|
|
<table cellspacing="0" cellpadding="0" width="400" summary="">
|
|
<tr>
|
|
<td>
|
|
<em>
|
|
``The nice thing about standards is that there are so many to choose from.
|
|
And if you really don't like all the standards you just have to wait another
|
|
year until the one arises you are looking for.''
|
|
</em>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td align="right">
|
|
<font size="-1">
|
|
A. Tanenbaum, ``Introduction to Computer Networks''
|
|
</font>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
<p>As an introduction this chapter is aimed at readers who are familiar
|
|
with the Web, HTTP, and Apache, but are not security experts. It is not
|
|
intended to be a definitive guide to the SSL protocol, nor does it discuss
|
|
specific techniques for managing certificates in an organization, or the
|
|
important legal issues of patents and import and export restrictions. Rather,
|
|
it is intended to provide a common background to mod_ssl users by pulling
|
|
together various concepts, definitions, and examples as a starting point for
|
|
further exploration.</p>
|
|
|
|
<p>The presented content is mainly derived, with permission by the author, from
|
|
the article <a
|
|
href="http://www.ultranet.com/~fhirsch/Papers/wwwj/index.html"><em>Introducing SSL
|
|
and Certificates using SSLeay</em></a> from <a
|
|
href="http://www.ultranet.com/~fhirsch/">Frederick J. Hirsch</a>, of The Open
|
|
Group Research Institute, which was published in <a
|
|
href="http://www.ora.com/catalog/wjsum97/"><em>Web Security: A Matter of
|
|
Trust</em></a>, World Wide Web Journal, Volume 2, Issue 3, Summer 1997.
|
|
Please send any postive feedback to <a
|
|
href="mailto:fjh@alum.mit.edu">Frederick Hirsch</a> (the original
|
|
article author) and all negative feedback to <a
|
|
href="mailto:rse@engelschall.com">Ralf S. Engelschall</a> (the mod_ssl
|
|
author).</p>
|
|
|
|
<ul>
|
|
<li><a href="#ToC1">Cryptographic Techniques</a></li>
|
|
<li><a href="#ToC2">Cryptographic Algorithms</a></li>
|
|
<li><a href="#ToC3">Message Digests</a></li>
|
|
<li><a href="#ToC4">Digital Signatures</a></li>
|
|
<li><a href="#ToC5">Certificates</a></li>
|
|
<li><a href="#ToC6">Certificate Contents</a></li>
|
|
<li><a href="#ToC7">Certificate Authorities</a></li>
|
|
<li><a href="#ToC8">Certificate Chains</a></li>
|
|
<li><a href="#ToC9">Creating a Root-Level CA</a></li>
|
|
<li><a href="#ToC10">Certificate Management</a></li>
|
|
<li><a href="#ToC11">Secure Sockets Layer (SSL)</a></li>
|
|
<li><a href="#ToC12">Session Establishment</a></li>
|
|
<li><a href="#ToC13">Key Exchange Method</a></li>
|
|
<li><a href="#ToC14">Cipher for Data Transfer</a></li>
|
|
<li><a href="#ToC15">Digest Function</a></li>
|
|
<li><a href="#ToC16">Handshake Sequence Protocol</a></li>
|
|
<li><a href="#ToC17">Data Transfer</a></li>
|
|
<li><a href="#ToC18">Securing HTTP Communication</a></li>
|
|
<li><a href="#ToC19">References</a></li>
|
|
</ul>
|
|
|
|
<h2><a name="ToC1">Cryptographic Techniques</a></h2>
|
|
<p>Understanding SSL requires an understanding of cryptographic algorithms,
|
|
message digest functions (aka. one-way or hash functions), and digital
|
|
signatures. These techniques are the subject of entire books (see for instance
|
|
[<a href="#AC96">AC96</a>]) and provide the basis for privacy, integrity, and
|
|
authentication.</p>
|
|
<h3><a name="ToC2">Cryptographic Algorithms</a></h3>
|
|
<p>Suppose Alice wants to send a message to her bank to transfer some money.
|
|
Alice would like the message to be private, since it will include information
|
|
such as her account number and transfer amount. One solution is to use a
|
|
cryptographic algorithm, a technique that would transform her message into an
|
|
encrypted form, unreadable except by those it is intended for. Once in this
|
|
form, the message may only be interpreted through the use of a secret key.
|
|
Without the key the message is useless: good cryptographic algorithms make it
|
|
so difficult for intruders to decode the original text that it isn't worth
|
|
their effort.</p>
|
|
<p>There are two categories of cryptographic algorithms:
|
|
conventional and public key.</p>
|
|
<ul>
|
|
<li><em>Conventional cryptography</em>, also known as symmetric
|
|
cryptography, requires the sender and receiver to share a key: a secret
|
|
piece of information that may be used to encrypt or decrypt a message.
|
|
If this key is secret, then nobody other than the sender or receiver may
|
|
read the message. If Alice and the bank know a secret key, then they
|
|
may send each other private messages. The task of privately choosing a key
|
|
before communicating, however, can be problematic.<br />
|
|
<br />
|
|
</li>
|
|
<li><em>Public key cryptography</em>, also known as asymmetric cryptography,
|
|
solves the key exchange problem by defining an algorithm which uses two keys,
|
|
each of which may be used to encrypt a message. If one key is used to encrypt
|
|
a message then the other must be used to decrypt it. This makes it possible
|
|
to receive secure messages by simply publishing one key (the public key) and
|
|
keeping the other secret (the private key).
|
|
</li>
|
|
</ul>
|
|
<p>Anyone may encrypt a message using the public key, but only the owner of the
|
|
private key will be able to read it. In this way, Alice may send private
|
|
messages to the owner of a key-pair (the bank), by encrypting it using their
|
|
public key. Only the bank will be able to decrypt it.</p>
|
|
|
|
<h3><a name="ToC3">Message Digests</a></h3>
|
|
<p>Although Alice may encrypt her message to make it private, there is still a
|
|
concern that someone might modify her original message or substitute
|
|
it with a different one, in order to transfer the money to themselves, for
|
|
instance. One way of guaranteeing the integrity of Alice's message is to
|
|
create a concise summary of her message and send this to the bank as well.
|
|
Upon receipt of the message, the bank creates its own summary and compares it
|
|
with the one Alice sent. If they agree then the message was received intact.</p>
|
|
<p>A summary such as this is called a <em>message digest</em>, <em>one-way
|
|
function</em> or <em>hash function</em>. Message digests are used to create
|
|
short, fixed-length representations of longer, variable-length messages.
|
|
Digest algorithms are designed to produce unique digests for different
|
|
messages. Message digests are designed to make it too difficult to determine
|
|
the message from the digest, and also impossible to find two different
|
|
messages which create the same digest -- thus eliminating the possibility of
|
|
substituting one message for another while maintaining the same digest.</p>
|
|
<p>Another challenge that Alice faces is finding a way to send the digest to the
|
|
bank securely; when this is achieved, the integrity of the associated message
|
|
is assured. One way to to this is to include the digest in a digital
|
|
signature.</p>
|
|
<h3><a name="ToC4">Digital Signatures</a></h3>
|
|
<p>When Alice sends a message to the bank, the bank needs to ensure that the
|
|
message is really from her, so an intruder does not request a transaction
|
|
involving her account. A <em>digital signature</em>, created by Alice and
|
|
included with the message, serves this purpose.</p>
|
|
<p>Digital signatures are created by encrypting a digest of the message,
|
|
and other information (such as a sequence number) with the sender's
|
|
private key. Though anyone may <em>decrypt</em> the signature using the public
|
|
key, only the signer knows the private key. This means that only they may
|
|
have signed it. Including the digest in the signature means the signature is
|
|
only good for that message; it also ensures the integrity of the message since
|
|
no one can change the digest and still sign it.</p>
|
|
<p>To guard against interception and reuse of the signature by an intruder at a
|
|
later date, the signature contains a unique sequence number. This protects
|
|
the bank from a fraudulent claim from Alice that she did not send the message
|
|
-- only she could have signed it (non-repudiation).</p>
|
|
<h2><a name="ToC5">Certificates</a></h2>
|
|
<p>Although Alice could have sent a private message to the bank, signed it, and
|
|
ensured the integrity of the message, she still needs to be sure that she is
|
|
really communicating with the bank. This means that she needs to be sure that
|
|
the public key she is using corresponds to the bank's private key. Similarly,
|
|
the bank also needs to verify that the message signature really corresponds to
|
|
Alice's signature.</p>
|
|
<p>If each party has a certificate which validates the other's identity, confirms
|
|
the public key, and is signed by a trusted agency, then they both will be
|
|
assured that they are communicating with whom they think they are. Such a
|
|
trusted agency is called a <em>Certificate Authority</em>, and certificates are
|
|
used for authentication.</p>
|
|
<h3><a name="ToC6">Certificate Contents</a></h3>
|
|
<p>A certificate associates a public key with the real identity of an individual,
|
|
server, or other entity, known as the subject. As shown in <a
|
|
href="#table1">Table 1</a>, information about the subject includes identifying
|
|
information (the distinguished name), and the public key. It also includes
|
|
the identification and signature of the Certificate Authority that issued the
|
|
certificate, and the period of time during which the certificate is valid. It
|
|
may have additional information (or extensions) as well as administrative
|
|
information for the Certificate Authority's use, such as a serial number.</p>
|
|
<div align="center">
|
|
<a name="table1"></a>
|
|
<table width="600" cellspacing="0" cellpadding="1" border="0" summary="">
|
|
<caption align="bottom">Table 1: Certificate Information</caption>
|
|
<tr>
|
|
<td bgcolor="#cccccc">
|
|
<table width="598" cellpadding="5" cellspacing="0" border="0" summary="">
|
|
<tr>
|
|
<td valign="top" align="center" bgcolor="#ffffff">
|
|
<table summary="">
|
|
<tr valign="top">
|
|
<td><b>Subject:</b></td>
|
|
<td>Distinguished Name, Public Key</td>
|
|
</tr>
|
|
<tr valign="top">
|
|
<td><b>Issuer:</b></td>
|
|
<td>Distinguished Name, Signature</td>
|
|
</tr>
|
|
<tr>
|
|
<td><b>Period of Validity:</b></td>
|
|
<td>Not Before Date, Not After Date</td>
|
|
</tr>
|
|
<tr>
|
|
<td><b>Administrative Information:</b></td>
|
|
<td>Version, Serial Number</td>
|
|
</tr>
|
|
<tr>
|
|
<td><b>Extended Information:</b></td>
|
|
<td>Basic Contraints, Netscape Flags, etc.</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
<p>A distinguished name is used to provide an identity in a specific context --
|
|
for instance, an individual might have a personal certificate as well as one
|
|
for their identity as an employee. Distinguished names are defined by the
|
|
X.509 standard [<a href="#X509">X509</a>], which defines the fields, field
|
|
names, and abbreviations used to refer to the fields
|
|
(see <a href="#table2">Table 2</a>).</p>
|
|
|
|
<div align="center">
|
|
<a name="table2"></a>
|
|
<table width="600" cellspacing="0" cellpadding="1" border="0" summary="">
|
|
<caption align="bottom">Table 2: Distinguished Name Information</caption>
|
|
<tr>
|
|
<td bgcolor="#cccccc">
|
|
<table width="598" cellpadding="5" cellspacing="0" border="0" summary="">
|
|
<tr>
|
|
<td valign="top" align="center" bgcolor="#ffffff">
|
|
<table summary="">
|
|
<tr valign="top">
|
|
<td><b>DN Field:</b></td>
|
|
<td><b>Abbrev.:</b></td>
|
|
<td><b>Description:</b></td>
|
|
<td><b>Example:</b></td>
|
|
</tr>
|
|
<tr valign="top">
|
|
<td>Common Name</td>
|
|
<td>CN</td>
|
|
<td>Name being certified</td>
|
|
<td>CN=Joe Average</td>
|
|
</tr>
|
|
<tr valign="top">
|
|
<td>Organization or Company</td>
|
|
<td>O</td>
|
|
<td>Name is associated with this<br />organization</td>
|
|
<td>O=Snake Oil, Ltd.</td>
|
|
</tr>
|
|
<tr valign="top">
|
|
<td>Organizational Unit</td>
|
|
<td>OU</td>
|
|
<td>Name is associated with this <br />organization unit, such as a department</td>
|
|
<td>OU=Research Institute</td>
|
|
</tr>
|
|
<tr valign="top">
|
|
<td>City/Locality</td>
|
|
<td>L</td>
|
|
<td>Name is located in this City</td>
|
|
<td>L=Snake City</td>
|
|
</tr>
|
|
<tr valign="top">
|
|
<td>State/Province</td>
|
|
<td>ST</td>
|
|
<td>Name is located in this State/Province</td>
|
|
<td>ST=Desert</td>
|
|
</tr>
|
|
<tr valign="top">
|
|
<td>Country</td>
|
|
<td>C</td>
|
|
<td>Name is located in this Country (ISO code)</td>
|
|
<td>C=XZ</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
<p>A Certificate Authority may define a policy specifying which distinguished
|
|
field names are optional, and which are required. It may also place
|
|
requirements upon the field contents, as may users of certificates. As an
|
|
example, a Netscape browser requires that the Common Name for a certificate
|
|
representing a server has a name which matches a wildcard pattern for the
|
|
domain name of that server, such as <code>*.snakeoil.com</code>.</p>
|
|
<p>The binary format of a certificate is defined using the ASN.1 notation [ <a
|
|
href="#X208">X208</a>] [<a href="#PKCS">PKCS</a>]. This notation defines how to
|
|
specify the contents, and encoding rules define how this information is
|
|
translated into binary form. The binary encoding of the certificate is
|
|
defined using Distinguished Encoding Rules (DER), which are based on the more
|
|
general Basic Encoding Rules (BER). For those transmissions which cannot
|
|
handle binary, the binary form may be translated into an ASCII form by using
|
|
Base64 encoding [<a href="#MIME">MIME</a>]. This encoded version is called PEM
|
|
encoded (the name comes from "Privacy Enhanced Mail"), when placed between
|
|
begin and end delimiter lines as illustrated in <a href="#table3">Table 3</a>.</p>
|
|
|
|
<div align="center">
|
|
<a name="table3"></a>
|
|
<table width="600" cellspacing="0" cellpadding="1" border="0" summary="">
|
|
<caption align="bottom">Table 3: Example of a PEM-encoded certificate (snakeoil.crt)</caption>
|
|
<tr><td bgcolor="#cccccc">
|
|
<table width="598" cellpadding="5" cellspacing="0" border="0" summary="">
|
|
<tr><td valign="top" align="center" bgcolor="#ffffff">
|
|
<table cellspacing="0" cellpadding="0" summary=""><tr><td>
|
|
<div class="code"><pre>
|
|
-----BEGIN CERTIFICATE-----
|
|
MIIC7jCCAlegAwIBAgIBATANBgkqhkiG9w0BAQQFADCBqTELMAkGA1UEBhMCWFkx
|
|
FTATBgNVBAgTDFNuYWtlIERlc2VydDETMBEGA1UEBxMKU25ha2UgVG93bjEXMBUG
|
|
A1UEChMOU25ha2UgT2lsLCBMdGQxHjAcBgNVBAsTFUNlcnRpZmljYXRlIEF1dGhv
|
|
cml0eTEVMBMGA1UEAxMMU25ha2UgT2lsIENBMR4wHAYJKoZIhvcNAQkBFg9jYUBz
|
|
bmFrZW9pbC5kb20wHhcNOTgxMDIxMDg1ODM2WhcNOTkxMDIxMDg1ODM2WjCBpzEL
|
|
MAkGA1UEBhMCWFkxFTATBgNVBAgTDFNuYWtlIERlc2VydDETMBEGA1UEBxMKU25h
|
|
a2UgVG93bjEXMBUGA1UEChMOU25ha2UgT2lsLCBMdGQxFzAVBgNVBAsTDldlYnNl
|
|
cnZlciBUZWFtMRkwFwYDVQQDExB3d3cuc25ha2VvaWwuZG9tMR8wHQYJKoZIhvcN
|
|
AQkBFhB3d3dAc25ha2VvaWwuZG9tMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKB
|
|
gQDH9Ge/s2zcH+da+rPTx/DPRp3xGjHZ4GG6pCmvADIEtBtKBFAcZ64n+Dy7Np8b
|
|
vKR+yy5DGQiijsH1D/j8HlGE+q4TZ8OFk7BNBFazHxFbYI4OKMiCxdKzdif1yfaa
|
|
lWoANFlAzlSdbxeGVHoT0K+gT5w3UxwZKv2DLbCTzLZyPwIDAQABoyYwJDAPBgNV
|
|
HRMECDAGAQH/AgEAMBEGCWCGSAGG+EIBAQQEAwIAQDANBgkqhkiG9w0BAQQFAAOB
|
|
gQAZUIHAL4D09oE6Lv2k56Gp38OBDuILvwLg1v1KL8mQR+KFjghCrtpqaztZqcDt
|
|
2q2QoyulCgSzHbEGmi0EsdkPfg6mp0penssIFePYNI+/8u9HT4LuKMJX15hxBam7
|
|
dUHzICxBVC1lnHyYGjDuAMhe396lYAn8bCld1/L4NMGBCQ==
|
|
-----END CERTIFICATE-----</pre></div>
|
|
</td></tr></table>
|
|
</td>
|
|
</tr></table>
|
|
</td></tr></table>
|
|
</div>
|
|
<h3><a name="ToC7">Certificate Authorities</a></h3>
|
|
<p>By first verifying the information in a certificate request before granting
|
|
the certificate, the Certificate Authority assures the identity of the private
|
|
key owner of a key-pair. For instance, if Alice requests a personal
|
|
certificate, the Certificate Authority must first make sure that Alice really
|
|
is the person the certificate request claims.</p>
|
|
<h4><a name="ToC8">Certificate Chains</a></h4>
|
|
<p>A Certificate Authority may also issue a certificate for another Certificate
|
|
Authority. When examining a certificate, Alice may need to examine the
|
|
certificate of the issuer, for each parent Certificate Authority, until
|
|
reaching one which she has confidence in. She may decide to trust only
|
|
certificates with a limited chain of issuers, to reduce her risk of a "bad"
|
|
certificate in the chain.</p>
|
|
<h4><a name="ToC9">Creating a Root-Level CA</a></h4>
|
|
<p>As noted earlier, each certificate requires an issuer to assert the validity
|
|
of the identity of the certificate subject, up to the top-level Certificate
|
|
Authority (CA). This presents a problem: Since this is who vouches for the
|
|
certificate of the top-level authority, which has no issuer?
|
|
In this unique case, the certificate is "self-signed", so the issuer of the
|
|
certificate is the same as the subject. As a result, one must exercise extra
|
|
care in trusting a self-signed certificate. The wide publication of a public
|
|
key by the root authority reduces the risk in trusting this key -- it would be
|
|
obvious if someone else publicized a key claiming to be the authority.
|
|
Browsers are preconfigured to trust well-known certificate authorities.</p>
|
|
<p>A number of companies, such as <a href="http://www.thawte.com/">Thawte</a> and
|
|
<a href="http://www.verisign.com/">VeriSign</a> have established themselves as
|
|
Certificate Authorities. These companies provide the following services:</p>
|
|
<ul>
|
|
<li>Verifying certificate requests</li>
|
|
<li>Processing certificate requests</li>
|
|
<li>Issuing and managing certificates</li>
|
|
</ul>
|
|
<p>It is also possible to create your own Certificate Authority. Although risky
|
|
in the Internet environment, it may be useful within an Intranet where the
|
|
organization can easily verify the identities of individuals and servers.</p>
|
|
<h4><a name="ToC10">Certificate Management</a></h4>
|
|
<p>Establishing a Certificate Authority is a responsibility which requires a
|
|
solid administrative, technical, and management framework.
|
|
Certificate Authorities not only issue certificates, they also manage them --
|
|
that is, they determine how long certificates are valid, they renew them, and
|
|
they keep lists of certificates that have already been issued but are no
|
|
longer valid (Certificate Revocation Lists, or CRLs).
|
|
Say Alice is entitled to a certificate as an employee of a company. Say too,
|
|
that the certificate needs to be revoked when Alice leaves the company. Since
|
|
certificates are objects that get passed around, it is impossible to tell from
|
|
the certificate alone that it has been revoked.
|
|
When examining certificates for validity, therefore, it is necessary to
|
|
contact the issuing Certificate Authority to check CRLs -- this is not usually
|
|
an automated part of the process.</p>
|
|
<div align="center"><b>Note:</b></div>
|
|
<p>If you use a Certificate Authority that is not configured into browsers by
|
|
default, it is necessary to load the Certificate Authority certificate into
|
|
the browser, enabling the browser to validate server certificates signed by
|
|
that Certificate Authority. Doing so may be dangerous, since once loaded, the
|
|
browser will accept all certificates signed by that Certificate Authority.</p>
|
|
<h2><a name="ToC11">Secure Sockets Layer (SSL)</a></h2>
|
|
<p>The Secure Sockets Layer protocol is a protocol layer which may be placed
|
|
between a reliable connection-oriented network layer protocol (e.g. TCP/IP)
|
|
and the application protocol layer (e.g. HTTP). SSL provides for secure
|
|
communication between client and server by allowing mutual authentication, the
|
|
use of digital signatures for integrity, and encryption for privacy.</p>
|
|
<p>The protocol is designed to support a range of choices for specific algorithms
|
|
used for cryptography, digests, and signatures. This allows algorithm
|
|
selection for specific servers to be made based on legal, export or other
|
|
concerns, and also enables the protocol to take advantage of new algorithms.
|
|
Choices are negotiated between client and server at the start of establishing
|
|
a protocol session.</p>
|
|
<div align="center">
|
|
<a name="table4"></a>
|
|
<table width="600" cellspacing="0" cellpadding="1" border="0" summary="">
|
|
<caption align="bottom">Table 4: Versions of the SSL protocol</caption>
|
|
<tr>
|
|
<td bgcolor="#cccccc">
|
|
<table width="598" cellpadding="5" cellspacing="0" border="0" summary="">
|
|
<tr>
|
|
<td valign="top" align="center" bgcolor="#ffffff">
|
|
<table summary="">
|
|
<tr valign="top">
|
|
<td><b>Version:</b></td>
|
|
<td><b>Source:</b></td>
|
|
<td><b>Description:</b></td>
|
|
<td><b>Browser Support:</b></td>
|
|
</tr>
|
|
<tr valign="top">
|
|
<td>SSL v2.0</td>
|
|
<td>Vendor Standard (from Netscape Corp.) [<a href="#SSL2">SSL2</a>]</td>
|
|
<td>First SSL protocol for which implementations exists</td>
|
|
<td>- NS Navigator 1.x/2.x<br />
|
|
- MS IE 3.x<br />
|
|
- Lynx/2.8+OpenSSL
|
|
</td>
|
|
</tr>
|
|
<tr valign="top">
|
|
<td>SSL v3.0</td>
|
|
<td>Expired Internet Draft (from Netscape Corp.) [<a href="#SSL3">SSL3</a>]</td>
|
|
<td>Revisions to prevent specific security attacks, add non-RSA ciphers, and support for certificate chains</td>
|
|
<td>- NS Navigator 2.x/3.x/4.x<br />
|
|
- MS IE 3.x/4.x<br />
|
|
- Lynx/2.8+OpenSSL
|
|
</td>
|
|
</tr>
|
|
<tr valign="top">
|
|
<td>TLS v1.0</td>
|
|
<td>Proposed Internet Standard (from IETF) [<a href="#TLS1">TLS1</a>]</td>
|
|
<td>Revision of SSL 3.0 to update the MAC layer to HMAC, add block padding for
|
|
block ciphers, message order standardization and more alert messages.
|
|
</td>
|
|
<td>- Lynx/2.8+OpenSSL</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
<p>There are a number of versions of the SSL protocol, as shown in <a
|
|
href="#table4">Table 4</a>. As noted there, one of the benefits in SSL 3.0 is
|
|
that it adds support of certificate chain loading. This feature allows a
|
|
server to pass a server certificate along with issuer certificates to the
|
|
browser. Chain loading also permits the browser to validate the server
|
|
certificate, even if Certificate Authority certificates are not installed for
|
|
the intermediate issuers, since they are included in the certificate chain.
|
|
SSL 3.0 is the basis for the Transport Layer Security [<a
|
|
href="#TLS1">TLS</a>] protocol standard, currently in development by the
|
|
Internet Engineering Task Force (IETF).</p>
|
|
<h3><a name="ToC12">Session Establishment</a></h3>
|
|
<p>The SSL session is established by following a <a>handshake sequence</a>
|
|
between client and server, as shown in <a href="#figure1">Figure 1</a>. This
|
|
sequence may vary, depending on whether the server is configured to provide a
|
|
server certificate or request a client certificate. Though cases exist where
|
|
additional handshake steps are required for management of cipher information,
|
|
this article summarizes one common scenario: see the SSL specification for the
|
|
full range of possibilities.</p>
|
|
<div align="center"><b>Note</b></div>
|
|
<p>Once an SSL session has been established it may be reused, thus avoiding the
|
|
performance penalty of repeating the many steps needed to start a session.
|
|
For this the server assigns each SSL session a unique session identifier which
|
|
is cached in the server and which the client can use on forthcoming
|
|
connections to reduce the handshake (until the session identifer expires in
|
|
the cache of the server).</p>
|
|
<div align="center">
|
|
<a name="figure1"></a>
|
|
<table width="600" cellspacing="0" cellpadding="1" border="0" summary="">
|
|
<caption align="bottom">Figure 1: Simplified SSL Handshake Sequence</caption>
|
|
<tr>
|
|
<td bgcolor="#cccccc">
|
|
<table width="598" cellpadding="5" cellspacing="0" border="0" summary="">
|
|
<tr>
|
|
<td valign="top" align="center" bgcolor="#ffffff">
|
|
<img src="ssl_intro_fig1.gif" alt="" width="423" height="327" />
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
<p>The elements of the handshake sequence, as used by the client and server, are
|
|
listed below:</p>
|
|
<ol>
|
|
<li>Negotiate the Cipher Suite to be used during data transfer</li>
|
|
<li>Establish and share a session key between client and server</li>
|
|
<li>Optionally authenticate the server to the client</li>
|
|
<li>Optionally authenticate the client to the server</li>
|
|
</ol>
|
|
<p>The first step, Cipher Suite Negotiation, allows the client and server to
|
|
choose a Cipher Suite supportable by both of them. The SSL3.0 protocol
|
|
specification defines 31 Cipher Suites. A Cipher Suite is defined by the
|
|
following components:</p>
|
|
<ul>
|
|
<li>Key Exchange Method</li>
|
|
<li>Cipher for Data Transfer</li>
|
|
<li>Message Digest for creating the Message Authentication Code (MAC)</li>
|
|
</ul>
|
|
<p>These three elements are described in the sections that follow.</p>
|
|
<h3><a name="ToC13">Key Exchange Method</a></h3>
|
|
<p>The key exchange method defines how the shared secret symmetric cryptography
|
|
key used for application data transfer will be agreed upon by client and
|
|
server. SSL 2.0 uses RSA key exchange only, while SSL 3.0 supports a choice of
|
|
key exchange algorithms including the RSA key exchange when certificates are
|
|
used, and Diffie-Hellman key exchange for exchanging keys without certificates
|
|
and without prior communication between client and server.</p>
|
|
<p>One variable in the choice of key exchange methods is digital signatures --
|
|
whether or not to use them, and if so, what kind of signatures to use.
|
|
Signing with a private key provides assurance against a
|
|
man-in-the-middle-attack during the information exchange used in generating
|
|
the shared key [<a href="#AC96">AC96</a>, p516].</p>
|
|
<h3><a name="ToC14">Cipher for Data Transfer</a></h3>
|
|
<p>SSL uses the conventional cryptography algorithm (symmetric cryptography)
|
|
described earlier for encrypting messages in a session. There are nine
|
|
choices, including the choice to perform no encryption:</p>
|
|
<ul>
|
|
<li>No encryption</li>
|
|
<li>Stream Ciphers
|
|
<ul>
|
|
<li>RC4 with 40-bit keys</li>
|
|
<li>RC4 with 128-bit keys</li>
|
|
</ul>
|
|
</li>
|
|
<li>CBC Block Ciphers
|
|
<ul>
|
|
<li>RC2 with 40 bit key</li>
|
|
<li>DES with 40 bit key</li>
|
|
<li>DES with 56 bit key</li>
|
|
<li>Triple-DES with 168 bit key</li>
|
|
<li>Idea (128 bit key)</li>
|
|
<li>Fortezza (96 bit key)</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
<p>Here "CBC" refers to Cipher Block Chaining, which means that a portion of the
|
|
previously encrypted cipher text is used in the encryption of the current
|
|
block. "DES" refers to the Data Encryption Standard [<a href="#AC96">AC96</a>,
|
|
ch12], which has a number of variants (including DES40 and 3DES_EDE). "Idea"
|
|
is one of the best and cryptographically strongest available algorithms, and
|
|
"RC2" is a proprietary algorithm from RSA DSI [<a href="#AC96">AC96</a>,
|
|
ch13].</p>
|
|
<h3><a name="ToC15">Digest Function</a></h3>
|
|
<p>The choice of digest function determines how a digest is created from a record
|
|
unit. SSL supports the following:</p>
|
|
<ul>
|
|
<li>No digest (Null choice)</li>
|
|
<li>MD5, a 128-bit hash</li>
|
|
<li>Secure Hash Algorithm (SHA-1), a 160-bit hash</li>
|
|
</ul>
|
|
<p>The message digest is used to create a Message Authentication Code (MAC) which
|
|
is encrypted with the message to provide integrity and to prevent against
|
|
replay attacks.</p>
|
|
<h3><a name="ToC16">Handshake Sequence Protocol</a></h3>
|
|
<p>The handshake sequence uses three protocols:</p>
|
|
<ul>
|
|
<li>The <em>SSL Handshake Protocol</em>
|
|
for performing the client and server SSL session establishment.
|
|
</li>
|
|
<li>The <em>SSL Change Cipher Spec Protocol</em> for actually establishing agreement
|
|
on the Cipher Suite for the session.
|
|
</li>
|
|
<li>The <em>SSL Alert Protocol</em> for
|
|
conveying SSL error messages between client and server.
|
|
</li>
|
|
</ul>
|
|
These protocols, as well as application protocol data, are encapsulated in the
|
|
<em>SSL Record Protocol</em>, as shown in <a href="#figure2">Figure 2</a>. An
|
|
encapsulated protocol is transferred as data by the lower layer protocol,
|
|
which does not examine the data. The encapsulated protocol has no knowledge of
|
|
the underlying protocol.
|
|
<div align="center">
|
|
<a name="figure2"></a>
|
|
<table width="600" cellspacing="0" cellpadding="1" border="0" summary="">
|
|
<caption align="bottom">Figure 2: SSL Protocol Stack</caption>
|
|
<tr>
|
|
<td bgcolor="#cccccc">
|
|
<table width="598" cellpadding="5" cellspacing="0" border="0" summary="">
|
|
<tr>
|
|
<td valign="top" align="center" bgcolor="#ffffff">
|
|
<img src="ssl_intro_fig2.gif" alt="" width="428" height="217" />
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
<p>The encapsulation of SSL control protocols by the record protocol means that
|
|
if an active session is renegotiated the control protocols will be transmitted
|
|
securely. If there were no session before, then the Null cipher suite is
|
|
used, which means there is no encryption and messages have no integrity
|
|
digests until the session has been established.</p>
|
|
<h3><a name="ToC17">Data Transfer</a></h3>
|
|
<p>The SSL Record Protocol, shown in <a href="#figure3">Figure 3</a>, is used to
|
|
transfer application and SSL Control data between the client and server,
|
|
possibly fragmenting this data into smaller units, or combining multiple
|
|
higher level protocol data messages into single units. It may compress, attach
|
|
digest signatures, and encrypt these units before transmitting them using the
|
|
underlying reliable transport protocol (Note: currently all major SSL
|
|
implementations lack support for compression).</p>
|
|
<div align="center">
|
|
<a name="figure3"></a>
|
|
<table width="600" cellspacing="0" cellpadding="1" border="0" summary="">
|
|
<caption align="bottom">Figure 3: SSL Record Protocol</caption>
|
|
<tr>
|
|
<td bgcolor="#cccccc">
|
|
<table width="598" cellpadding="5" cellspacing="0" border="0" summary="">
|
|
<tr>
|
|
<td valign="top" align="center" bgcolor="#ffffff">
|
|
<img src="ssl_intro_fig3.gif" alt="" width="423" height="323" />
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
<h3><a name="ToC18">Securing HTTP Communication</a></h3>
|
|
<p>One common use of SSL is to secure Web HTTP communication between a browser
|
|
and a webserver. This case does not preclude the use of non-secured HTTP. The
|
|
secure version is mainly plain HTTP over SSL (named HTTPS), but with one major
|
|
difference: it uses the URL scheme <code>https</code> rather than
|
|
<code>http</code> and a different server port (by default 443). This mainly
|
|
is what mod_ssl provides to you for the Apache webserver...</p>
|
|
<h2><a name="ToC19">References</a></h2>
|
|
<ul>
|
|
<li><a name="AC96"></a>
|
|
[AC96] Bruce Schneier, <em>Applied Cryptography</em>, 2nd Edition, Wiley,
|
|
1996. See <a href="http://www.counterpane.com/">http://www.counterpane.com/</a> for
|
|
various other materials by Bruce Schneier.
|
|
</li>
|
|
<li><a name="X208"></a>
|
|
[X208] ITU-T Recommendation X.208, <em>Specification of Abstract Syntax Notation
|
|
One (ASN.1)</em>, 1988. See for instance <a
|
|
href="ftp://ftp.neda.com/pub/itu/x.series/x208.ps">
|
|
ftp://ftp.neda.com/pub/itu/x.series/x208.ps</a>.
|
|
</li>
|
|
<li><a name="X509"></a>
|
|
[X509] ITU-T Recommendation X.509, <em>The Directory - Authentication
|
|
Framework</em>, 1988. See for instance <a
|
|
href="ftp://ftp.bull.com/pub/OSIdirectory/ITUnov96/X.509/97x509final.doc">
|
|
ftp://ftp.bull.com/pub/OSIdirectory/ITUnov96/X.509/97x509final.doc</a>.
|
|
</li>
|
|
<li><a name="PKCS"></a>
|
|
[PKCS] Kaliski, Burton S., Jr., <em>An Overview of the PKCS Standards</em>, An RSA
|
|
Laboratories Technical Note, revised November 1, 1993.
|
|
See <a href="http://www.rsa.com/rsalabs/pubs/PKCS/">
|
|
http://www.rsa.com/rsalabs/pubs/PKCS/</a>.
|
|
</li>
|
|
<li><a name="MIME"></a>
|
|
[MIME] N. Freed, N. Borenstein, <em>Multipurpose Internet Mail Extensions
|
|
(MIME) Part One: Format of Internet Message Bodies</em>, RFC2045.
|
|
See for instance <a href="ftp://ftp.isi.edu/in-notes/rfc2045.txt">
|
|
ftp://ftp.isi.edu/in-notes/rfc2045.txt</a>.
|
|
</li>
|
|
<li><a name="SSL2"></a>
|
|
[SSL2] Kipp E.B. Hickman, <em>The SSL Protocol</em>, 1995.
|
|
See <a href="http://www.netscape.com/eng/security/SSL_2.html">
|
|
http://www.netscape.com/eng/security/SSL_2.html</a>.
|
|
</li>
|
|
<li><a name="SSL3"></a>
|
|
[SSL3] Alan O. Freier, Philip Karlton, Paul C. Kocher, <em>The SSL Protocol
|
|
Version 3.0</em>, 1996. See <a
|
|
href="http://www.netscape.com/eng/ssl3/draft302.txt">
|
|
http://www.netscape.com/eng/ssl3/draft302.txt</a>.
|
|
</li>
|
|
<li><a name="TLS1"></a>
|
|
[TLS1] Tim Dierks, Christopher Allen, <em>The TLS Protocol Version 1.0</em>,
|
|
1997. See <a
|
|
href="ftp://ftp.ietf.org/internet-drafts/draft-ietf-tls-protocol-06.txt">
|
|
ftp://ftp.ietf.org/internet-drafts/draft-ietf-tls-protocol-06.txt</a>.
|
|
</li>
|
|
</ul>
|
|
<!--#include virtual="footer.html" -->
|
|
</body>
|
|
</html>
|