Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / Orcas / NetFXw7 / ndp / fx / src / xsp / System / Web / Extensions / ClientServices / ClientFormsIdentity.cs / 1 / 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
- EdmScalarPropertyAttribute.cs
- CustomValidator.cs
- MethodCallConverter.cs
- InkPresenterAutomationPeer.cs
- tooltip.cs
- PtsCache.cs
- ToolboxItemFilterAttribute.cs
- CompilerErrorCollection.cs
- BuildProviderCollection.cs
- selecteditemcollection.cs
- URLString.cs
- ModelItemCollectionImpl.cs
- ReferenceEqualityComparer.cs
- TextModifier.cs
- GridSplitterAutomationPeer.cs
- SettingsBindableAttribute.cs
- Drawing.cs
- ModelVisual3D.cs
- MostlySingletonList.cs
- InputMethodStateTypeInfo.cs
- QueryContinueDragEventArgs.cs
- ConfigurationManager.cs
- AnimationClockResource.cs
- FacetEnabledSchemaElement.cs
- ValidationErrorCollection.cs
- WindowsMenu.cs
- SemaphoreSecurity.cs
- BitConverter.cs
- WebSysDescriptionAttribute.cs
- XmlEncoding.cs
- PackWebRequestFactory.cs
- MethodToken.cs
- NonBatchDirectoryCompiler.cs
- Setter.cs
- TakeOrSkipQueryOperator.cs
- StyleXamlParser.cs
- _SslState.cs
- TransformValueSerializer.cs
- Pkcs7Recipient.cs
- SchemaNamespaceManager.cs
- XmlDocumentSerializer.cs
- PhysicalFontFamily.cs
- ContentValidator.cs
- HierarchicalDataSourceIDConverter.cs
- SoapEnumAttribute.cs
- RangeContentEnumerator.cs
- XsltConvert.cs
- QuarticEase.cs
- Sequence.cs
- DataSourceListEditor.cs
- ExceptionCollection.cs
- RegexCapture.cs
- SafeProcessHandle.cs
- CodeAttributeArgument.cs
- AsyncCompletedEventArgs.cs
- CodeSnippetStatement.cs
- RedistVersionInfo.cs
- ConversionHelper.cs
- XmlMembersMapping.cs
- storepermissionattribute.cs
- DirectoryObjectSecurity.cs
- CultureInfo.cs
- TypeLoadException.cs
- MetadataArtifactLoaderFile.cs
- AsyncOperationContext.cs
- DataGridViewCellPaintingEventArgs.cs
- ScriptReference.cs
- EvidenceTypeDescriptor.cs
- CodeCatchClause.cs
- HtmlTitle.cs
- UrlPropertyAttribute.cs
- TemplateBuilder.cs
- SqlDataSourceConfigureSortForm.cs
- EntityProviderFactory.cs
- DisableDpiAwarenessAttribute.cs
- ProxyGenerationError.cs
- BindingList.cs
- AppDomainUnloadedException.cs
- SqlDataRecord.cs
- XmlSerializerSection.cs
- ExceptionNotification.cs
- ToolStripArrowRenderEventArgs.cs
- ResourceBinder.cs
- DataKey.cs
- StreamUpdate.cs
- ParallelTimeline.cs
- WindowsFormsHost.cs
- PageParser.cs
- PerformanceCounterLib.cs
- HostedTcpTransportManager.cs
- EntityDesignerDataSourceView.cs
- ApplicationServiceManager.cs
- FixedDocumentSequencePaginator.cs
- XmlSchemaSet.cs
- Menu.cs
- ReachSerializableProperties.cs
- DbDataSourceEnumerator.cs
- TableLayoutRowStyleCollection.cs
- XamlWriterExtensions.cs
- VerbConverter.cs