Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / ndp / fx / src / xsp / System / Web / Extensions / ClientServices / ClientFormsIdentity.cs / 2 / ClientFormsIdentity.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.ClientServices { using System; using System.Net; using System.Security.Principal; using System.Runtime.InteropServices; using System.Security; using System.Web.Security; using System.Diagnostics.CodeAnalysis; public class ClientFormsIdentity : IIdentity, IDisposable { public string Name { get { return _Name; }} public bool IsAuthenticated { get { return _IsAuthenticated; }} public string AuthenticationType { get { return _AuthenticationType; } } public CookieContainer AuthenticationCookies { get { return _AuthenticationCookies; } } public MembershipProvider Provider { get { return _Provider; } } public ClientFormsIdentity(string name, string password, MembershipProvider provider, string authenticationType, bool isAuthenticated, CookieContainer authenticationCookies) { _Name = name; _AuthenticationType = authenticationType; _IsAuthenticated = isAuthenticated; _AuthenticationCookies = authenticationCookies; _Password = GetSecureStringFromString(password); _Provider = provider; } public void RevalidateUser() { if (_Disposed) { throw new ObjectDisposedException(this.GetType().FullName); } _Provider.ValidateUser(_Name, GetStringFromSecureString(_Password)); } public void Dispose() { Dispose(true); GC.SuppressFinalize(this); } protected virtual void Dispose(bool disposing) { if (disposing) { if (_Password != null) { _Password.Dispose(); } } _Disposed = true; } private string _Name; private bool _IsAuthenticated; private string _AuthenticationType; private CookieContainer _AuthenticationCookies; private SecureString _Password; private MembershipProvider _Provider; private bool _Disposed; private static SecureString GetSecureStringFromString(string password) { char[] passwordChars = password.ToCharArray(); SecureString ss = new SecureString(); for (int iter = 0; iter < passwordChars.Length; iter++) ss.AppendChar(passwordChars[iter]); ss.MakeReadOnly(); return ss; } [SuppressMessage("Microsoft.Security", "CA2122:DoNotIndirectlyExposeMethodsWithLinkDemands", Justification="Reviewed and approved by feature crew")] private static string GetStringFromSecureString(SecureString securePass) { IntPtr bstr = IntPtr.Zero; try { bstr = Marshal.SecureStringToBSTR(securePass); return Marshal.PtrToStringBSTR(bstr); } finally { if (bstr != IntPtr.Zero) Marshal.FreeBSTR(bstr); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.ClientServices { using System; using System.Net; using System.Security.Principal; using System.Runtime.InteropServices; using System.Security; using System.Web.Security; using System.Diagnostics.CodeAnalysis; public class ClientFormsIdentity : IIdentity, IDisposable { public string Name { get { return _Name; }} public bool IsAuthenticated { get { return _IsAuthenticated; }} public string AuthenticationType { get { return _AuthenticationType; } } public CookieContainer AuthenticationCookies { get { return _AuthenticationCookies; } } public MembershipProvider Provider { get { return _Provider; } } public ClientFormsIdentity(string name, string password, MembershipProvider provider, string authenticationType, bool isAuthenticated, CookieContainer authenticationCookies) { _Name = name; _AuthenticationType = authenticationType; _IsAuthenticated = isAuthenticated; _AuthenticationCookies = authenticationCookies; _Password = GetSecureStringFromString(password); _Provider = provider; } public void RevalidateUser() { if (_Disposed) { throw new ObjectDisposedException(this.GetType().FullName); } _Provider.ValidateUser(_Name, GetStringFromSecureString(_Password)); } public void Dispose() { Dispose(true); GC.SuppressFinalize(this); } protected virtual void Dispose(bool disposing) { if (disposing) { if (_Password != null) { _Password.Dispose(); } } _Disposed = true; } private string _Name; private bool _IsAuthenticated; private string _AuthenticationType; private CookieContainer _AuthenticationCookies; private SecureString _Password; private MembershipProvider _Provider; private bool _Disposed; private static SecureString GetSecureStringFromString(string password) { char[] passwordChars = password.ToCharArray(); SecureString ss = new SecureString(); for (int iter = 0; iter < passwordChars.Length; iter++) ss.AppendChar(passwordChars[iter]); ss.MakeReadOnly(); return ss; } [SuppressMessage("Microsoft.Security", "CA2122:DoNotIndirectlyExposeMethodsWithLinkDemands", Justification="Reviewed and approved by feature crew")] private static string GetStringFromSecureString(SecureString securePass) { IntPtr bstr = IntPtr.Zero; try { bstr = Marshal.SecureStringToBSTR(securePass); return Marshal.PtrToStringBSTR(bstr); } finally { if (bstr != IntPtr.Zero) Marshal.FreeBSTR(bstr); } } } } // 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
- VBIdentifierTrimConverter.cs
- MsmqIntegrationOutputChannel.cs
- DataGridViewElement.cs
- StorageAssociationSetMapping.cs
- JoinTreeSlot.cs
- StreamUpgradeAcceptor.cs
- X509Extension.cs
- Attributes.cs
- UpnEndpointIdentityExtension.cs
- PartitionedStream.cs
- Size3DConverter.cs
- SoapExtension.cs
- AddInDeploymentState.cs
- HierarchicalDataBoundControl.cs
- TypeSystemHelpers.cs
- XmlElement.cs
- InternalsVisibleToAttribute.cs
- MenuItemBindingCollection.cs
- OleDbException.cs
- XmlCDATASection.cs
- BindingMemberInfo.cs
- ObjectManager.cs
- StorageBasedPackageProperties.cs
- DesignerOptionService.cs
- NonSerializedAttribute.cs
- Hex.cs
- IdentityNotMappedException.cs
- Interlocked.cs
- CircleHotSpot.cs
- PlainXmlDeserializer.cs
- TypeForwardedToAttribute.cs
- IsolatedStorageException.cs
- PassportAuthenticationEventArgs.cs
- Visual.cs
- MissingMemberException.cs
- odbcmetadatacolumnnames.cs
- CheckBoxAutomationPeer.cs
- indexingfiltermarshaler.cs
- DbMetaDataFactory.cs
- SynchronizationContext.cs
- PassportAuthenticationEventArgs.cs
- XmlAttributeHolder.cs
- DataChangedEventManager.cs
- PaperSize.cs
- DataGridClipboardHelper.cs
- sortedlist.cs
- PaperSize.cs
- ActionNotSupportedException.cs
- CachedTypeface.cs
- UdpMessageProperty.cs
- ObjectQuery_EntitySqlExtensions.cs
- ItemList.cs
- PipelineComponent.cs
- WebHostScriptMappingsInstallComponent.cs
- FormatException.cs
- ValidatedControlConverter.cs
- SystemResources.cs
- SmiGettersStream.cs
- ContravarianceAdapter.cs
- HttpApplicationFactory.cs
- MetaTable.cs
- XmlSchemaAppInfo.cs
- TableRowGroup.cs
- PageThemeCodeDomTreeGenerator.cs
- VoiceChangeEventArgs.cs
- AnnotationComponentChooser.cs
- ScrollPattern.cs
- DateTimeStorage.cs
- ToolStripRenderEventArgs.cs
- ContentType.cs
- CodeConstructor.cs
- LambdaValue.cs
- PointKeyFrameCollection.cs
- ObjectDisposedException.cs
- Size.cs
- AutoGeneratedFieldProperties.cs
- SizeAnimationBase.cs
- CodeNamespaceCollection.cs
- NameValueConfigurationElement.cs
- DeferredElementTreeState.cs
- DummyDataSource.cs
- WindowsListViewScroll.cs
- DoubleAnimationBase.cs
- TextCompositionEventArgs.cs
- WindowInteropHelper.cs
- ListArgumentProvider.cs
- Journal.cs
- ColumnBinding.cs
- BulletDecorator.cs
- DefaultPerformanceCounters.cs
- TemplatedMailWebEventProvider.cs
- SoundPlayer.cs
- CfgParser.cs
- LoginName.cs
- PropertyInformationCollection.cs
- ToolStripRenderEventArgs.cs
- UserNameSecurityTokenParameters.cs
- DesignerSerializationOptionsAttribute.cs
- FormsAuthenticationUserCollection.cs
- DetailsViewRowCollection.cs