Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / 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
- SiteOfOriginContainer.cs
- ProtocolsConfigurationEntry.cs
- StoreItemCollection.Loader.cs
- PerspectiveCamera.cs
- CompositeScriptReferenceEventArgs.cs
- DrawingGroup.cs
- DropDownButton.cs
- RenderCapability.cs
- SHA512Managed.cs
- ToolStripButton.cs
- FloaterBaseParaClient.cs
- DataSourceControl.cs
- RectKeyFrameCollection.cs
- ConfigurationElementProperty.cs
- TargetControlTypeCache.cs
- Soap.cs
- Image.cs
- SchemaInfo.cs
- ListControl.cs
- ProfileSection.cs
- Msmq4SubqueuePoisonHandler.cs
- ComplexPropertyEntry.cs
- RepeaterItem.cs
- CharEntityEncoderFallback.cs
- TabPanel.cs
- WorkflowInstanceProxy.cs
- iisPickupDirectory.cs
- SystemIcmpV6Statistics.cs
- Encoder.cs
- DetailsViewInsertEventArgs.cs
- LabelEditEvent.cs
- ExternalFile.cs
- CustomTypeDescriptor.cs
- MarkupExtensionReturnTypeAttribute.cs
- DataRelationPropertyDescriptor.cs
- PublisherMembershipCondition.cs
- ToolBarPanel.cs
- RepeaterCommandEventArgs.cs
- OverrideMode.cs
- SerialStream.cs
- Type.cs
- PrimitiveType.cs
- PopupRoot.cs
- AssociatedControlConverter.cs
- TreeNode.cs
- XamlFrame.cs
- Crc32Helper.cs
- GridItem.cs
- HostedController.cs
- FrameworkContentElementAutomationPeer.cs
- JavaScriptSerializer.cs
- CodeGeneratorOptions.cs
- WaitHandleCannotBeOpenedException.cs
- QuerySubExprEliminator.cs
- Model3DCollection.cs
- OpenTypeCommon.cs
- TextBox.cs
- util.cs
- MultiPageTextView.cs
- MultipleViewPattern.cs
- ClientSideProviderDescription.cs
- XmlHierarchicalEnumerable.cs
- DefaultProfileManager.cs
- SQLGuidStorage.cs
- AppDomainUnloadedException.cs
- ColorDialog.cs
- DataControlFieldHeaderCell.cs
- SoapSchemaImporter.cs
- ViewPort3D.cs
- RuntimeVariableList.cs
- CreateInstanceBinder.cs
- ComboBoxAutomationPeer.cs
- BamlRecordHelper.cs
- ResolvedKeyFrameEntry.cs
- PrincipalPermission.cs
- EntityContainerEntitySet.cs
- WebConfigurationManager.cs
- GestureRecognizer.cs
- LabelExpression.cs
- DrawingState.cs
- BlockUIContainer.cs
- DayRenderEvent.cs
- CompressEmulationStream.cs
- RootContext.cs
- ResourceType.cs
- TypeLoadException.cs
- DataGridViewEditingControlShowingEventArgs.cs
- ArrayExtension.cs
- EntityDataSource.cs
- Material.cs
- SuppressMergeCheckAttribute.cs
- SqlCacheDependency.cs
- DotExpr.cs
- GridItemProviderWrapper.cs
- Geometry3D.cs
- AtomicFile.cs
- MessageQueueConverter.cs
- DataGridViewRowCollection.cs
- MetafileHeaderWmf.cs
- safelink.cs