S/MIME
From Wikipedia, the free encyclopedia
S/MIME (Secure / Multipurpose Internet Mail Extensions) is a standard for public key encryption and signing of e-mail encapsulated in MIME.
Contents |
[edit] History
S/MIME was originally developed by RSA Data Security Inc. The original specification used the recently developed IETF MIME specification with the de facto industry standard PKCS #7 secure message format.
Change control to S/MIME has since been vested in the IETF and the specification is now layered on Cryptographic Message Syntax, an IETF specification that is identical in most respects with PKCS #7.
[edit] Function
S/MIME provides the following cryptographic security services for electronic messaging applications: authentication, message integrity and non-repudiation of origin (using digital signatures) and privacy and data security (using encryption). S/MIME specifies the application/pkcs7-mime (smime-type "enveloped-data") type for data enveloping (encrypting): the whole (prepared) MIME entity to be enveloped is encrypted and packed into an object which subsequently is inserted into an application/pkcs7-mime MIME entity.
S/MIME functionality is built into the vast majority of modern e-mail software and interoperates between them.
[edit] S/MIME Certificates
Before S/MIME can be utilized in any of the above applications, one must obtain and install an individual key/certificate either from one's in-house certificate authority (CA) or from a public CA such as one of those listed below. Best practice is to use separate private keys (and associated certificates) for Signature and for Encryption, as this permits escrow of the encryption key without compromise to the non-repudiation property of the signature key. Encryption requires having the destination party's certificate on store (which is typically automatic upon receiving a message from the party with a valid signing certificate). While it is technically possible to send a message encrypted (using the destination party certificate) without having one's own certificate to digitally sign, in practice, the S/MIME clients will require you install your own certificate before they allow encrypting to others.
A typical basic personal certificate verifies the owner's identity only in terms of binding them to an email address and does not verify the person's name or business. The latter, if needed (e.g. for signing contracts), can be obtained through CAs that offer further verification (digital notary) services or managed PKI service. For more detail on authentication, see Digital Signature.
Depending on the policy of the CA, your certificate and all its contents may be posted publicly for reference and verification. This makes your name and email address available for all to see and possibly search for. Other CAs only post serial numbers and revocation status, which does not include any of the personal information. The latter, at a minimum, is mandatory to uphold the integrity of the public key infrastructure.
[edit] Obstacles to deploying S/MIME in practice
- S/MIME is not properly suited for use via webmail clients. Though support can be hacked into a browser, (as with the GMail plugin above), security requires the private key to be kept accessible to the user but inaccessible from the webmail server, complicating the key webmail advantage of providing ubiquitous accessibility. This issue is not specific to S/MIME - any secure method of signing webmail requires a browser to execute code to produce the signature.
- S/MIME is tailored for end to end security. Encryption will not only encrypt your messages, but also malware. Thus if your mail is scanned for malware anywhere but at the end points, such as your company's gateway, encryption might defeat the detector while successfully delivering the malware. Solutions:
- Perform malware scanning on end user stations after decryption.
- Store private keys on the gateway server so decryption can occur prior to the gateway malware scan.
- Use message content scanners specifically designed to check the content of encrypted messages in transit whilst preserving end-to-end signatures and encryption. Such solutions must contain built-in protection for both the private key used to decrypt the message, and for the temporarily decrypted content.
[edit] See also
- MIME Multipurpose Internet Mail Extensions
- TLS Transport Layer Security, formerly SSL
- Email Encryption
- E-mail authentication
- Pretty Good Privacy (PGP)
- GnuPG
[edit] External links
- S/MIME working group charter — has links to S/MIME related RFCs and internet drafts.
- How to forge an S/MIME signature — critique on some S/MIME implementations.
- S/MIME IETF Working Group
- S/MIME and OpenPGP
- E-mail Client Testing for S/MIME Compliance
- VeriSign's Public Directory (ldap://directory.verisign.com)
- MozillaZine Knowledge Base: Getting an SMIME certificate