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
- storepermission.cs
- XmlQueryTypeFactory.cs
- FixedPosition.cs
- NotFiniteNumberException.cs
- Suspend.cs
- RectAnimationUsingKeyFrames.cs
- TemplateContainer.cs
- RelationshipConverter.cs
- ObjectDataSourceEventArgs.cs
- DetailsViewPageEventArgs.cs
- DbConnectionPoolIdentity.cs
- ObjectParameterCollection.cs
- PersonalizationProviderHelper.cs
- TypeTypeConverter.cs
- DelegatedStream.cs
- BufferAllocator.cs
- DataGridViewTopLeftHeaderCell.cs
- EncodingInfo.cs
- CurrentTimeZone.cs
- CodeExpressionStatement.cs
- EventLogEntry.cs
- SwitchAttribute.cs
- HighlightVisual.cs
- CompilerCollection.cs
- SqlEnums.cs
- DocumentViewerAutomationPeer.cs
- ConfigXmlElement.cs
- TableLayoutColumnStyleCollection.cs
- DbCommandTree.cs
- ReceiveReply.cs
- EncryptRequest.cs
- AddInAttribute.cs
- UIElementAutomationPeer.cs
- FunctionParameter.cs
- RequestCache.cs
- XmlTextAttribute.cs
- XmlC14NWriter.cs
- NotImplementedException.cs
- XPathSingletonIterator.cs
- BitmapFrameDecode.cs
- _KerberosClient.cs
- EncodingTable.cs
- CalendarAutoFormatDialog.cs
- UnsafeNativeMethods.cs
- ConfigXmlElement.cs
- XmlSchemaAttributeGroup.cs
- RawStylusActions.cs
- StringStorage.cs
- XmlNodeChangedEventArgs.cs
- tabpagecollectioneditor.cs
- XPathScanner.cs
- FontResourceCache.cs
- ColorBlend.cs
- SimpleType.cs
- XPathExpr.cs
- AuthenticationService.cs
- RegistrationServices.cs
- Vertex.cs
- PropertyChangedEventManager.cs
- handlecollector.cs
- HttpRuntimeSection.cs
- QilChoice.cs
- ExtentKey.cs
- BitmapData.cs
- ModuleConfigurationInfo.cs
- AsyncPostBackTrigger.cs
- BitmapEffectvisualstate.cs
- ZoneMembershipCondition.cs
- Int32.cs
- XmlMapping.cs
- ParameterToken.cs
- CompositionDesigner.cs
- ProfileInfo.cs
- TextElementEnumerator.cs
- TransformConverter.cs
- WriteableBitmap.cs
- GeneralTransformGroup.cs
- CodeBlockBuilder.cs
- ISO2022Encoding.cs
- DomainUpDown.cs
- InputScope.cs
- UdpDiscoveryEndpoint.cs
- Pen.cs
- Crypto.cs
- DATA_BLOB.cs
- ColorContextHelper.cs
- DataGridTextColumn.cs
- FileSecurity.cs
- FrameworkEventSource.cs
- TimerElapsedEvenArgs.cs
- COM2Properties.cs
- DataGridColumn.cs
- DesignerObjectListAdapter.cs
- DecimalAnimationUsingKeyFrames.cs
- XmlReflectionMember.cs
- Action.cs
- EntitySqlQueryBuilder.cs
- Imaging.cs
- ImagingCache.cs
- BitmapEffectDrawingContextState.cs