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
- PointIndependentAnimationStorage.cs
- ClientConfigurationHost.cs
- WindowVisualStateTracker.cs
- DataSourceNameHandler.cs
- ExpressionConverter.cs
- MetadataItem.cs
- LinqDataSourceDisposeEventArgs.cs
- DocumentOrderQuery.cs
- ModelPerspective.cs
- HtmlButton.cs
- ObsoleteAttribute.cs
- ISSmlParser.cs
- Frame.cs
- CultureTable.cs
- StylusPointPropertyInfo.cs
- GAC.cs
- ConnectionOrientedTransportManager.cs
- AdRotator.cs
- TypeUtil.cs
- VSWCFServiceContractGenerator.cs
- RegexWorker.cs
- TimeZone.cs
- BitmapDownload.cs
- SQLMembershipProvider.cs
- SerialPinChanges.cs
- CacheSection.cs
- RoutedEventConverter.cs
- ValidatorCollection.cs
- RangeValidator.cs
- BitmapEffectCollection.cs
- DateTimeOffsetConverter.cs
- DropTarget.cs
- HttpWriter.cs
- AttributeSetAction.cs
- XmlSchemaObject.cs
- Label.cs
- ViewValidator.cs
- CodeVariableReferenceExpression.cs
- XmlStreamStore.cs
- TableCell.cs
- PtsContext.cs
- RoutedPropertyChangedEventArgs.cs
- ExceptionHandler.cs
- ConnectionInterfaceCollection.cs
- WindowsFont.cs
- SiteMapHierarchicalDataSourceView.cs
- ECDiffieHellmanCngPublicKey.cs
- MaskedTextProvider.cs
- MessageBuilder.cs
- DrawListViewSubItemEventArgs.cs
- PeerApplicationLaunchInfo.cs
- ObjectSpanRewriter.cs
- SerialStream.cs
- ArrayExtension.cs
- IncrementalHitTester.cs
- TemplateModeChangedEventArgs.cs
- SerialPinChanges.cs
- Attribute.cs
- SkinBuilder.cs
- RealizationContext.cs
- UInt16Storage.cs
- ThreadBehavior.cs
- RootProfilePropertySettingsCollection.cs
- TextUtf8RawTextWriter.cs
- ContextInformation.cs
- CommandHelpers.cs
- CaseInsensitiveHashCodeProvider.cs
- Int64KeyFrameCollection.cs
- CategoryGridEntry.cs
- FormClosedEvent.cs
- FrameworkName.cs
- Crypto.cs
- DbProviderFactory.cs
- XamlDesignerSerializationManager.cs
- TransactionBridgeSection.cs
- UIElementIsland.cs
- RadioButton.cs
- TypeResolvingOptionsAttribute.cs
- TransferRequestHandler.cs
- DefaultTraceListener.cs
- SqlClientWrapperSmiStream.cs
- DataSourceXmlClassAttribute.cs
- Animatable.cs
- ColorPalette.cs
- ECDsaCng.cs
- IpcChannel.cs
- Decimal.cs
- CodeFieldReferenceExpression.cs
- FtpWebResponse.cs
- ExceptionDetail.cs
- DataGridState.cs
- CodeEventReferenceExpression.cs
- TypeConverter.cs
- Matrix.cs
- CheckBoxFlatAdapter.cs
- exports.cs
- ResourceReader.cs
- UDPClient.cs
- HttpClientCertificate.cs
- DataListItem.cs