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
- ArrayExtension.cs
- XmlStreamStore.cs
- CustomAttributeSerializer.cs
- StringFunctions.cs
- assertwrapper.cs
- NavigatorInput.cs
- HttpMethodConstraint.cs
- RequestChannel.cs
- RootProfilePropertySettingsCollection.cs
- ProfileSection.cs
- handlecollector.cs
- DataGridViewHitTestInfo.cs
- BaseValidatorDesigner.cs
- CssClassPropertyAttribute.cs
- AssociationSetEnd.cs
- Menu.cs
- OleDbException.cs
- UpdatePanelTriggerCollection.cs
- HtmlToClrEventProxy.cs
- CompleteWizardStep.cs
- AccessibleObject.cs
- CompareValidator.cs
- DefaultExpression.cs
- NativeWindow.cs
- CalendarDay.cs
- AcceptorSessionSymmetricTransportSecurityProtocol.cs
- FontStyles.cs
- XPathNode.cs
- DataTemplate.cs
- XmlDownloadManager.cs
- SetterTriggerConditionValueConverter.cs
- TextLineBreak.cs
- OleDbError.cs
- WindowInteropHelper.cs
- WebPartTransformerAttribute.cs
- DocumentApplication.cs
- OutputCacheSection.cs
- DataRecordObjectView.cs
- TemplateManager.cs
- XmlCodeExporter.cs
- IDispatchConstantAttribute.cs
- XmlBindingWorker.cs
- FlowDocumentView.cs
- ImmutableObjectAttribute.cs
- GotoExpression.cs
- XPathException.cs
- CodeEntryPointMethod.cs
- path.cs
- HtmlElementErrorEventArgs.cs
- UTF32Encoding.cs
- TableItemProviderWrapper.cs
- AutoResetEvent.cs
- DownloadProgressEventArgs.cs
- HMACSHA384.cs
- ScanQueryOperator.cs
- WindowsAltTab.cs
- LayoutEditorPart.cs
- TraceUtility.cs
- ConcurrentStack.cs
- DataControlImageButton.cs
- SiteMembershipCondition.cs
- ToolStripItemDesigner.cs
- NegatedConstant.cs
- AVElementHelper.cs
- RoutedEvent.cs
- RuntimeHelpers.cs
- BaseCAMarshaler.cs
- ProcessThread.cs
- PersonalizationProviderCollection.cs
- RelationshipEndCollection.cs
- IResourceProvider.cs
- BaseValidator.cs
- RepeaterItem.cs
- TraceContextEventArgs.cs
- WriteFileContext.cs
- ThaiBuddhistCalendar.cs
- DotExpr.cs
- RecognizerStateChangedEventArgs.cs
- CompensatableTransactionScopeActivityDesigner.cs
- Path.cs
- WsdlBuildProvider.cs
- CollectionViewGroupRoot.cs
- XmlSignificantWhitespace.cs
- ToggleProviderWrapper.cs
- SourceItem.cs
- SpStreamWrapper.cs
- Fx.cs
- AssemblyUtil.cs
- SynchronizationValidator.cs
- RijndaelManagedTransform.cs
- InheritanceAttribute.cs
- ScriptControlManager.cs
- SafeLocalMemHandle.cs
- SessionSwitchEventArgs.cs
- GetRecipientListRequest.cs
- TemplateInstanceAttribute.cs
- CaseExpr.cs
- PersistChildrenAttribute.cs
- RotateTransform3D.cs
- Hashtable.cs