Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / Net / System / Net / Mail / MailAddress.cs / 1305376 / MailAddress.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Net.Mail { using System; using System.Text; using System.Net.Mime; using System.Diagnostics; using System.Globalization; // // This class stores the basic components of an e-mail address as described in RFC 2822 Section 3.4. // Any parsing required is done with the MailAddressParser class. // public class MailAddress { // These components form an e-mail address when assembled as follows: // "EncodedDisplayname"private readonly Encoding displayNameEncoding; private readonly string displayName; private readonly string userName; private readonly string host; // For internal use only by MailAddressParser. // The components were already validated before this is called. internal MailAddress(string displayName, string userName, string domain) { this.host = domain; this.userName = userName; this.displayName = displayName; this.displayNameEncoding = Encoding.GetEncoding(MimeBasePart.defaultCharSet); Debug.Assert(host != null, "host was null in internal constructor"); Debug.Assert(userName != null, "userName was null in internal constructor"); Debug.Assert(displayName != null, "displayName was null in internal constructor"); } public MailAddress(string address) : this(address, null, (Encoding)null) { } public MailAddress(string address, string displayName) : this(address, displayName, (Encoding)null) { } // // This constructor validates and stores the components of an e-mail address. // // Preconditions: // - 'address' must not be null or empty. // // Postconditions: // - The e-mail address components from the given 'address' are parsed, which should be formatted as: // "EncodedDisplayname" // - If a 'displayName' is provided separately, it overrides whatever display name is parsed from the 'address' // field. The display name does not need to be pre-encoded if a 'displayNameEncoding' is provided. // // A FormatException will be thrown if any of the components in 'address' are invalid. public MailAddress(string address, string displayName, Encoding displayNameEncoding) { if (address == null){ throw new ArgumentNullException("address"); } if (address == String.Empty){ throw new ArgumentException(SR.GetString(SR.net_emptystringcall,"address"), "address"); } this.displayNameEncoding = displayNameEncoding ?? Encoding.GetEncoding(MimeBasePart.defaultCharSet); this.displayName = displayName ?? string.Empty; // Check for bounding quotes if (!String.IsNullOrEmpty(this.displayName)) { if (this.displayName.Length >= 2 && this.displayName[0] == '\"' && this.displayName[this.displayName.Length - 1] == '\"') { // Peal bounding quotes, they'll get re-added later. this.displayName = this.displayName.Substring(1, this.displayName.Length - 2); } } MailAddress result = MailAddressParser.ParseAddress(address); this.host = result.host; this.userName = result.userName; // If we were not given a display name, use the one parsed from 'address'. if (String.IsNullOrEmpty(this.displayName)) { this.displayName = result.displayName; } } public string DisplayName { get { return displayName; } } public string User { get { return this.userName; } } public string Host { get { return this.host; } } public string Address { get { return String.Format(CultureInfo.InvariantCulture, "{0}@{1}", userName, host); } } internal string SmtpAddress{ get{ return String.Format(CultureInfo.InvariantCulture, "<{0}>", Address); } } /// /// this returns the full address with quoted display name. /// i.e. "some email address display name" ////// if displayname is not provided then this returns only user@host (no angle brackets) /// public override string ToString() { if (String.IsNullOrEmpty(DisplayName)) { return this.Address; } else { return String.Format("\"{0}\" {1}", DisplayName, SmtpAddress); } } public override bool Equals(object value) { if (value == null) { return false; } return ToString().Equals(value.ToString(),StringComparison.InvariantCultureIgnoreCase); } public override int GetHashCode(){ return ToString().GetHashCode(); } static EncodedStreamFactory encoderFactory = new EncodedStreamFactory(); // Encodes the full email address, folding as needed internal string Encode(int charsConsumed) { string encodedAddress = String.Empty; IEncodableStream encoder; byte[] buffer; Debug.Assert(this.Address != null, "address was null"); //do we need to take into account the Display name? If so, encode it if (!String.IsNullOrEmpty(this.displayName)) { //figure out the encoding type. If it's all ASCII and contains no CRLF then //it does not need to be encoded for parity with other email clients. We will //however fold at the end of the display name so that the email address itself can //be appended. if (MimeBasePart.IsAscii(this.displayName, false)) { encodedAddress = String.Format("\"{0}\"", this.displayName); } else { //encode the displayname since it's non-ascii encoder = encoderFactory.GetEncoderForHeader(this.displayNameEncoding, false, charsConsumed); buffer = displayNameEncoding.GetBytes(this.displayName); encoder.EncodeBytes(buffer, 0, buffer.Length); encodedAddress = encoder.GetEncodedString(); } //the extra space is because there should be a non-printable whitespace char //following the fold (CRLF) and there is supposed to be a space between the display name and //the address so this is necessary. encodedAddress += "\r\n "; } //now we have the encoded display name (if present), we need to append the address to it. if (!String.IsNullOrEmpty(encodedAddress)) { //address should be enclosed in <> when a display name is present encodedAddress += SmtpAddress; } else { //no display name, just return the address encodedAddress = this.Address; } return encodedAddress; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ // // Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Net.Mail { using System; using System.Text; using System.Net.Mime; using System.Diagnostics; using System.Globalization; // // This class stores the basic components of an e-mail address as described in RFC 2822 Section 3.4. // Any parsing required is done with the MailAddressParser class. // public class MailAddress { // These components form an e-mail address when assembled as follows: // "EncodedDisplayname"private readonly Encoding displayNameEncoding; private readonly string displayName; private readonly string userName; private readonly string host; // For internal use only by MailAddressParser. // The components were already validated before this is called. internal MailAddress(string displayName, string userName, string domain) { this.host = domain; this.userName = userName; this.displayName = displayName; this.displayNameEncoding = Encoding.GetEncoding(MimeBasePart.defaultCharSet); Debug.Assert(host != null, "host was null in internal constructor"); Debug.Assert(userName != null, "userName was null in internal constructor"); Debug.Assert(displayName != null, "displayName was null in internal constructor"); } public MailAddress(string address) : this(address, null, (Encoding)null) { } public MailAddress(string address, string displayName) : this(address, displayName, (Encoding)null) { } // // This constructor validates and stores the components of an e-mail address. // // Preconditions: // - 'address' must not be null or empty. // // Postconditions: // - The e-mail address components from the given 'address' are parsed, which should be formatted as: // "EncodedDisplayname" // - If a 'displayName' is provided separately, it overrides whatever display name is parsed from the 'address' // field. The display name does not need to be pre-encoded if a 'displayNameEncoding' is provided. // // A FormatException will be thrown if any of the components in 'address' are invalid. public MailAddress(string address, string displayName, Encoding displayNameEncoding) { if (address == null){ throw new ArgumentNullException("address"); } if (address == String.Empty){ throw new ArgumentException(SR.GetString(SR.net_emptystringcall,"address"), "address"); } this.displayNameEncoding = displayNameEncoding ?? Encoding.GetEncoding(MimeBasePart.defaultCharSet); this.displayName = displayName ?? string.Empty; // Check for bounding quotes if (!String.IsNullOrEmpty(this.displayName)) { if (this.displayName.Length >= 2 && this.displayName[0] == '\"' && this.displayName[this.displayName.Length - 1] == '\"') { // Peal bounding quotes, they'll get re-added later. this.displayName = this.displayName.Substring(1, this.displayName.Length - 2); } } MailAddress result = MailAddressParser.ParseAddress(address); this.host = result.host; this.userName = result.userName; // If we were not given a display name, use the one parsed from 'address'. if (String.IsNullOrEmpty(this.displayName)) { this.displayName = result.displayName; } } public string DisplayName { get { return displayName; } } public string User { get { return this.userName; } } public string Host { get { return this.host; } } public string Address { get { return String.Format(CultureInfo.InvariantCulture, "{0}@{1}", userName, host); } } internal string SmtpAddress{ get{ return String.Format(CultureInfo.InvariantCulture, "<{0}>", Address); } } /// /// this returns the full address with quoted display name. /// i.e. "some email address display name" ////// if displayname is not provided then this returns only user@host (no angle brackets) /// public override string ToString() { if (String.IsNullOrEmpty(DisplayName)) { return this.Address; } else { return String.Format("\"{0}\" {1}", DisplayName, SmtpAddress); } } public override bool Equals(object value) { if (value == null) { return false; } return ToString().Equals(value.ToString(),StringComparison.InvariantCultureIgnoreCase); } public override int GetHashCode(){ return ToString().GetHashCode(); } static EncodedStreamFactory encoderFactory = new EncodedStreamFactory(); // Encodes the full email address, folding as needed internal string Encode(int charsConsumed) { string encodedAddress = String.Empty; IEncodableStream encoder; byte[] buffer; Debug.Assert(this.Address != null, "address was null"); //do we need to take into account the Display name? If so, encode it if (!String.IsNullOrEmpty(this.displayName)) { //figure out the encoding type. If it's all ASCII and contains no CRLF then //it does not need to be encoded for parity with other email clients. We will //however fold at the end of the display name so that the email address itself can //be appended. if (MimeBasePart.IsAscii(this.displayName, false)) { encodedAddress = String.Format("\"{0}\"", this.displayName); } else { //encode the displayname since it's non-ascii encoder = encoderFactory.GetEncoderForHeader(this.displayNameEncoding, false, charsConsumed); buffer = displayNameEncoding.GetBytes(this.displayName); encoder.EncodeBytes(buffer, 0, buffer.Length); encodedAddress = encoder.GetEncodedString(); } //the extra space is because there should be a non-printable whitespace char //following the fold (CRLF) and there is supposed to be a space between the display name and //the address so this is necessary. encodedAddress += "\r\n "; } //now we have the encoded display name (if present), we need to append the address to it. if (!String.IsNullOrEmpty(encodedAddress)) { //address should be enclosed in <> when a display name is present encodedAddress += SmtpAddress; } else { //no display name, just return the address encodedAddress = this.Address; } return encodedAddress; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ContractUtils.cs
- WindowsStatusBar.cs
- Domain.cs
- QuerySelectOp.cs
- SqlDataSourceParameterParser.cs
- ReferenceSchema.cs
- DataControlImageButton.cs
- CompatibleIComparer.cs
- TypeDelegator.cs
- OdbcConnectionString.cs
- DataGridCheckBoxColumn.cs
- DbException.cs
- XmlQueryType.cs
- WindowsStartMenu.cs
- XmlSchemaSubstitutionGroup.cs
- Compilation.cs
- HttpBrowserCapabilitiesWrapper.cs
- ClientSideProviderDescription.cs
- RegexStringValidator.cs
- exports.cs
- PersistChildrenAttribute.cs
- StatusBarItemAutomationPeer.cs
- Rule.cs
- _NestedSingleAsyncResult.cs
- UIHelper.cs
- ScaleTransform3D.cs
- ListViewInsertEventArgs.cs
- WebServiceErrorEvent.cs
- TextMessageEncodingBindingElement.cs
- _SslState.cs
- OleDbConnectionPoolGroupProviderInfo.cs
- TextPointer.cs
- OracleBFile.cs
- RepeaterDataBoundAdapter.cs
- EnumConverter.cs
- WebEncodingValidator.cs
- XmlDataSourceNodeDescriptor.cs
- UniqueConstraint.cs
- ModelServiceImpl.cs
- XPathAncestorQuery.cs
- CursorConverter.cs
- ContextMenuAutomationPeer.cs
- ReadWriteControlDesigner.cs
- MetadataPropertyCollection.cs
- GeometryModel3D.cs
- Timeline.cs
- TextTreeRootNode.cs
- ReferencedType.cs
- TdsEnums.cs
- DesignTimeParseData.cs
- LineGeometry.cs
- WebCategoryAttribute.cs
- WebPartConnectionsCancelEventArgs.cs
- ConstructorNeedsTagAttribute.cs
- StringOutput.cs
- StandardCommands.cs
- DesignerWidgets.cs
- DynamicResourceExtensionConverter.cs
- HostingEnvironmentSection.cs
- DateBoldEvent.cs
- HttpCacheVary.cs
- NumberFormatInfo.cs
- GraphicsState.cs
- InputMethodStateChangeEventArgs.cs
- ToolStripItemClickedEventArgs.cs
- SynchronizationContext.cs
- Rules.cs
- DesignTimeDataBinding.cs
- ManagedWndProcTracker.cs
- SoapTypeAttribute.cs
- RegistrationServices.cs
- DataGridViewRowStateChangedEventArgs.cs
- NativeRecognizer.cs
- TypeSemantics.cs
- SetState.cs
- HierarchicalDataSourceControl.cs
- CorrelationManager.cs
- DataGridViewColumnCollectionDialog.cs
- TextFormatterContext.cs
- TextFragmentEngine.cs
- BrushMappingModeValidation.cs
- DictionaryBase.cs
- TextPatternIdentifiers.cs
- ExtensionCollection.cs
- Hashtable.cs
- ADMembershipProvider.cs
- HtmlMeta.cs
- SmiEventSink.cs
- UriTemplateDispatchFormatter.cs
- translator.cs
- TagNameToTypeMapper.cs
- FixedTextView.cs
- QueryContinueDragEvent.cs
- TranslateTransform3D.cs
- PolyLineSegmentFigureLogic.cs
- DataViewSetting.cs
- ResourcePart.cs
- StubHelpers.cs
- SqlDataSourceAdvancedOptionsForm.cs
- UserInitiatedNavigationPermission.cs