5321 October 2008 Obsoletes: 2821 Updates: 1123 Category: Standards Track

5321 October 2008 Obsoletes: 2821 Updates: 1123 Category: Standards Track

Network Working Group J. Klensin Request for Comments: 5321 October 2008 Obsoletes: 2821 Updates: 1123 Category: Standards Track Simple Mail Transfer Protocol Status of This Memo This document specifies an Internet standards track protocol for the Internet community, and requests discussion and suggestions for improvements. Please refer to the current edition of the "Internet Official Protocol Standards" (STD 1) for the standardization state and status of this protocol. Distribution of this memo is unlimited. Abstract This document is a specification of the basic protocol for Internet electronic mail transport. It consolidates, updates, and clarifies several previous documents, making all or parts of most of them obsolete. It covers the SMTP extension mechanisms and best practices for the contemporary Internet, but does not provide details about particular extensions. Although SMTP was designed as a mail transport and delivery protocol, this specification also contains information that is important to its use as a "mail submission" protocol for "split-UA" (User Agent) mail reading systems and mobile environments. Klensin Standards Track [Page 1] RFC 5321 SMTP October 2008 Table of Contents 1. Introduction . 5 1.1. Transport of Electronic Mail . 5 1.2. History and Context for This Document . 5 1.3. Document Conventions . 6 2. The SMTP Model . 7 2.1. Basic Structure . 7 2.2. The Extension Model . 9 2.2.1. Background . 9 2.2.2. Definition and Registration of Extensions . 10 2.2.3. Special Issues with Extensions . 11 2.3. SMTP Terminology . 11 2.3.1. Mail Objects . 11 2.3.2. Senders and Receivers . 12 2.3.3. Mail Agents and Message Stores . 12 2.3.4. Host . 13 2.3.5. Domain Names . 13 2.3.6. Buffer and State Table . 14 2.3.7. Commands and Replies . 14 2.3.8. Lines . 14 2.3.9. Message Content and Mail Data . 15 2.3.10. Originator, Delivery, Relay, and Gateway Systems . 15 2.3.11. Mailbox and Address . 15 2.4. General Syntax Principles and Transaction Model . 16 3. The SMTP Procedures: An Overview . 17 3.1. Session Initiation . 18 3.2. Client Initiation . 18 3.3. Mail Transactions . 19 3.4. Forwarding for Address Correction or Updating . 21 3.5. Commands for Debugging Addresses . 22 3.5.1. Overview . 22 3.5.2. VRFY Normal Response . 24 3.5.3. Meaning of VRFY or EXPN Success Response . 25 3.5.4. Semantics and Applications of EXPN . 26 3.6. Relaying and Mail Routing . 26 3.6.1. Source Routes and Relaying . 26 3.6.2. Mail eXchange Records and Relaying . 26 3.6.3. Message Submission Servers as Relays . 27 3.7. Mail Gatewaying . 28 3.7.1. Header Fields in Gatewaying . 28 3.7.2. Received Lines in Gatewaying . 29 3.7.3. Addresses in Gatewaying . 29 3.7.4. Other Header Fields in Gatewaying . 29 3.7.5. Envelopes in Gatewaying . 30 3.8. Terminating Sessions and Connections . 30 3.9. Mailing Lists and Aliases . 31 3.9.1. Alias . 31 Klensin Standards Track [Page 2] RFC 5321 SMTP October 2008 3.9.2. List . 31 4. The SMTP Specifications . 32 4.1. SMTP Commands . 32 4.1.1. Command Semantics and Syntax . 32 4.1.2. Command Argument Syntax . 41 4.1.3. Address Literals . 43 4.1.4. Order of Commands . 44 4.1.5. Private-Use Commands . 46 4.2. SMTP Replies . 46 4.2.1. Reply Code Severities and Theory . 48 4.2.2. Reply Codes by Function Groups . 50 4.2.3. Reply Codes in Numeric Order . 52 4.2.4. Reply Code 502 . 53 4.2.5. Reply Codes after DATA and the Subsequent <CRLF>.<CRLF> . 53 4.3. Sequencing of Commands and Replies . 54 4.3.1. Sequencing Overview . 54 4.3.2. Command-Reply Sequences . 55 4.4. Trace Information . 57 4.5. Additional Implementation Issues . 61 4.5.1. Minimum Implementation . 61 4.5.2. Transparency . 62 4.5.3. Sizes and Timeouts . 62 4.5.3.1. Size Limits and Minimums . 62 4.5.3.1.1. Local-part . 63 4.5.3.1.2. Domain . 63 4.5.3.1.3. Path . 63 4.5.3.1.4. Command Line . 63 4.5.3.1.5. Reply Line . 63 4.5.3.1.6. Text Line . 63 4.5.3.1.7. Message Content . 63 4.5.3.1.8. Recipients Buffer . 64 4.5.3.1.9. Treatment When Limits Exceeded . 64 4.5.3.1.10. Too Many Recipients Code . 64 4.5.3.2. Timeouts . 65 4.5.3.2.1. Initial 220 Message: 5 Minutes . 65 4.5.3.2.2. MAIL Command: 5 Minutes . 65 4.5.3.2.3. RCPT Command: 5 Minutes . 65 4.5.3.2.4. DATA Initiation: 2 Minutes . 66 4.5.3.2.5. Data Block: 3 Minutes . 66 4.5.3.2.6. DATA Termination: 10 Minutes. 66 4.5.3.2.7. Server Timeout: 5 Minutes. 66 4.5.4. Retry Strategies . 66 4.5.5. Messages with a Null Reverse-Path . 68 5. Address Resolution and Mail Handling . 69 5.1. Locating the Target Host . 69 5.2. IPv6 and MX Records . 71 6. Problem Detection and Handling . 71 Klensin Standards Track [Page 3] RFC 5321 SMTP October 2008 6.1. Reliable Delivery and Replies by Email . 71 6.2. Unwanted, Unsolicited, and "Attack" Messages . 72 6.3. Loop Detection . 73 6.4. Compensating for Irregularities . 73 7. Security Considerations . 75 7.1. Mail Security and Spoofing . 75 7.2. "Blind" Copies . 76 7.3. VRFY, EXPN, and Security . 76 7.4. Mail Rerouting Based on the 251 and 551 Response Codes . 77 7.5. Information Disclosure in Announcements . 77 7.6. Information Disclosure in Trace Fields . 78 7.7. Information Disclosure in Message Forwarding . 78 7.8. Resistance to Attacks . 78 7.9. Scope of Operation of SMTP Servers . 78 8. IANA Considerations . 79 9. Acknowledgments . 80 10. References . 81 10.1. Normative References . 81 10.2. Informative References . 82 Appendix A. TCP Transport Service . 85 Appendix B. Generating SMTP Commands from RFC 822 Header Fields . 85 Appendix C. Source Routes . 86 Appendix D. Scenarios . 87 D.1. A Typical SMTP Transaction Scenario . 88 D.2. Aborted SMTP Transaction Scenario . 89 D.3. Relayed Mail Scenario . 90 D.4. Verifying and Sending Scenario . 92 Appendix E. Other Gateway Issues . 92 Appendix F. Deprecated Features of RFC 821 . 93 F.1. TURN . 93 F.2. Source Routing . 93 F.3. HELO . 93 F.4. #-literals . 94 F.5. Dates and Years . 94 F.6. Sending versus Mailing . 94 Klensin Standards Track [Page 4] RFC 5321 SMTP October 2008 1. Introduction 1.1. Transport of Electronic Mail The objective of the Simple Mail Transfer Protocol (SMTP) is to transfer mail reliably and efficiently. SMTP is independent of the particular transmission subsystem and requires only a reliable ordered data stream channel. While this document specifically discusses transport over TCP, other transports are possible. Appendices to RFC 821 [1] describe some of them. An important feature of SMTP is its capability to transport mail across multiple networks, usually referred to as "SMTP mail relaying" (see Section 3.6). A network consists of the mutually-TCP-accessible hosts on the public Internet, the mutually-TCP-accessible hosts on a firewall-isolated TCP/IP Intranet, or hosts in some other LAN or WAN environment utilizing a non-TCP transport-level protocol. Using SMTP, a process can transfer mail to another process on the same network or to some other network via a relay or gateway process accessible to both networks. In this way, a mail message may pass through a number of intermediate relay or gateway hosts on its path from sender to ultimate recipient. The Mail eXchanger mechanisms of the domain name system (RFC 1035 [2], RFC 974 [12], and Section 5 of this document) are used to identify the appropriate next-hop destination for a message being transported. 1.2. History and Context for This Document This document is a specification of the basic protocol for the Internet electronic mail transport. It consolidates, updates and clarifies, but does not add new or change existing functionality of the following: o the original SMTP (Simple Mail Transfer Protocol) specification of RFC 821 [1], o domain name system requirements and implications for mail transport from RFC 1035 [2] and RFC 974 [12], o the clarifications and applicability statements in RFC 1123 [3], and o material drawn from the SMTP Extension mechanisms in RFC 1869 [13]. Klensin Standards Track [Page 5] RFC 5321 SMTP October 2008 o Editorial and clarification changes to RFC 2821 [14] to bring that specification to Draft Standard. It obsoletes RFC 821, RFC 974, RFC 1869, and RFC 2821 and updates RFC 1123 (replacing the mail transport materials of RFC 1123). However, RFC 821 specifies some features that were not in significant use in the Internet by the mid-1990s and (in appendices) some additional transport models. Those sections are omitted here in the interest of clarity and brevity; readers needing them should refer to RFC 821. It also includes some additional material from RFC 1123 that required amplification. This material has been identified in multiple ways, mostly by tracking flaming on various lists and newsgroups and problems of unusual readings or interpretations that have appeared as the SMTP extensions have been deployed. Where this specification moves beyond consolidation and actually differs from earlier documents, it supersedes them technically as well as textually. Although SMTP was designed as a mail transport and delivery protocol, this specification also contains information that is important to its use as a "mail submission" protocol, as recommended for Post Office Protocol (POP) (RFC 937 [15], RFC 1939 [16]) and IMAP (RFC 3501 [17]).

View Full Text

Details

  • File Type
    pdf
  • Upload Time
    -
  • Content Languages
    English
  • Upload User
    Anonymous/Not logged-in
  • File Pages
    96 Page
  • File Size
    -

Download

Channel Download Status
Express Download Enable

Copyright

We respect the copyrights and intellectual property rights of all users. All uploaded documents are either original works of the uploader or authorized works of the rightful owners.

  • Not to be reproduced or distributed without explicit permission.
  • Not used for commercial purposes outside of approved use cases.
  • Not used to infringe on the rights of the original creators.
  • If you believe any content infringes your copyright, please contact us immediately.

Support

For help with questions, suggestions, or problems, please contact us