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
- ConfigurationPermission.cs
- FormsAuthenticationUser.cs
- DictionaryContent.cs
- PersistNameAttribute.cs
- ReadOnlyDictionary.cs
- RelatedCurrencyManager.cs
- WebPartVerbCollection.cs
- SortKey.cs
- Calendar.cs
- FontEditor.cs
- DataReceivedEventArgs.cs
- XamlStream.cs
- InputLanguageProfileNotifySink.cs
- DefaultValidator.cs
- ExpandCollapseProviderWrapper.cs
- SessionPageStatePersister.cs
- UncommonField.cs
- QilDataSource.cs
- DataGridItemCollection.cs
- COM2IDispatchConverter.cs
- BufferedWebEventProvider.cs
- __ComObject.cs
- EventLogPermission.cs
- UnsafeNativeMethods.cs
- SessionSymmetricMessageSecurityProtocolFactory.cs
- RadioButtonList.cs
- ValidationSummary.cs
- BamlCollectionHolder.cs
- DocumentApplication.cs
- SqlCacheDependency.cs
- PolyBezierSegment.cs
- CommonDialog.cs
- HttpContext.cs
- DetailsViewInsertEventArgs.cs
- WebPartEditorOkVerb.cs
- InitialServerConnectionReader.cs
- SqlClientMetaDataCollectionNames.cs
- Vars.cs
- SchemaObjectWriter.cs
- ExceptionUtility.cs
- ImportCatalogPart.cs
- IndependentAnimationStorage.cs
- HtmlTableCellCollection.cs
- LocalizabilityAttribute.cs
- ThicknessKeyFrameCollection.cs
- RegularExpressionValidator.cs
- DataFormats.cs
- PolicyVersionConverter.cs
- LineSegment.cs
- WindowsAuthenticationModule.cs
- WebCodeGenerator.cs
- CaseInsensitiveHashCodeProvider.cs
- BroadcastEventHelper.cs
- ConnectionPoint.cs
- BezierSegment.cs
- CLSCompliantAttribute.cs
- StandardBindingElement.cs
- RC2CryptoServiceProvider.cs
- GroupByQueryOperator.cs
- SerializationHelper.cs
- CryptoStream.cs
- Registry.cs
- BaseCodePageEncoding.cs
- ThumbButtonInfo.cs
- DiscoveryDocumentSearchPattern.cs
- EventLogPermissionAttribute.cs
- ExtractedStateEntry.cs
- LinearGradientBrush.cs
- XmlUtilWriter.cs
- DataSetUtil.cs
- TimerExtension.cs
- ExecutedRoutedEventArgs.cs
- CompoundFileReference.cs
- SystemEvents.cs
- NotCondition.cs
- IApplicationTrustManager.cs
- InfiniteTimeSpanConverter.cs
- Grid.cs
- BamlLocalizableResource.cs
- BridgeDataRecord.cs
- WebPartTracker.cs
- KnowledgeBase.cs
- HotSpotCollection.cs
- ZoneMembershipCondition.cs
- CheckBoxList.cs
- TextEncodedRawTextWriter.cs
- DataControlButton.cs
- CompilerState.cs
- HMAC.cs
- SchemaAttDef.cs
- AdCreatedEventArgs.cs
- InputGestureCollection.cs
- TcpChannelHelper.cs
- SqlException.cs
- BevelBitmapEffect.cs
- AddDataControlFieldDialog.cs
- LineInfo.cs
- GridViewColumnHeader.cs
- DataComponentGenerator.cs
- HashJoinQueryOperatorEnumerator.cs