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
- SoapInteropTypes.cs
- SystemNetworkInterface.cs
- XmlAttribute.cs
- WindowsProgressbar.cs
- ButtonColumn.cs
- NetTcpSecurityElement.cs
- SqlCommandSet.cs
- ProcessHost.cs
- Lease.cs
- PropertyBuilder.cs
- ColorAnimation.cs
- WebPartEventArgs.cs
- SiteMapNodeItemEventArgs.cs
- HttpInputStream.cs
- ProxyFragment.cs
- DBSqlParserColumn.cs
- SpnEndpointIdentityExtension.cs
- NoPersistProperty.cs
- EventMappingSettingsCollection.cs
- DateBoldEvent.cs
- Cursors.cs
- TargetInvocationException.cs
- SystemEvents.cs
- XsltContext.cs
- RectangleGeometry.cs
- Html32TextWriter.cs
- TextBoxView.cs
- DataSourceControl.cs
- MemberRelationshipService.cs
- SizeFConverter.cs
- MimeTextImporter.cs
- RuntimeCompatibilityAttribute.cs
- DrawingImage.cs
- DesignRelationCollection.cs
- ZipIOCentralDirectoryFileHeader.cs
- DesignerSerializerAttribute.cs
- ProtocolsConfiguration.cs
- ReadOnlyHierarchicalDataSource.cs
- DiagnosticTraceSource.cs
- ClaimSet.cs
- __FastResourceComparer.cs
- ExternalCalls.cs
- FilteredDataSetHelper.cs
- OperandQuery.cs
- XmlSchemaAttributeGroup.cs
- SchemaTypeEmitter.cs
- XmlSchemaCompilationSettings.cs
- QuaternionAnimation.cs
- ApplicationDirectoryMembershipCondition.cs
- GeneralTransform.cs
- DLinqColumnProvider.cs
- DataGridViewImageCell.cs
- SqlRewriteScalarSubqueries.cs
- SkewTransform.cs
- SubclassTypeValidatorAttribute.cs
- ConfigXmlCDataSection.cs
- InvalidDataException.cs
- ReferenceService.cs
- TypeConverterHelper.cs
- ReadOnlyDictionary.cs
- InputLanguageEventArgs.cs
- LockedHandleGlyph.cs
- LassoSelectionBehavior.cs
- FormatterServices.cs
- MaterializeFromAtom.cs
- ListViewSortEventArgs.cs
- StatusBarAutomationPeer.cs
- TrackingProvider.cs
- EditorOptionAttribute.cs
- CursorConverter.cs
- PermissionRequestEvidence.cs
- PropertyRecord.cs
- QilReplaceVisitor.cs
- OutputScopeManager.cs
- ProfileInfo.cs
- DLinqDataModelProvider.cs
- DESCryptoServiceProvider.cs
- HashMembershipCondition.cs
- ErrorHandler.cs
- DelegateHelpers.Generated.cs
- EventLogHandle.cs
- ValueUtilsSmi.cs
- AbstractDataSvcMapFileLoader.cs
- Context.cs
- ObjectDataSourceMethodEventArgs.cs
- BulletedList.cs
- RequestResponse.cs
- BindingSource.cs
- WindowPatternIdentifiers.cs
- ResourceKey.cs
- PathFigureCollectionConverter.cs
- HtmlInputSubmit.cs
- DataServiceResponse.cs
- URLMembershipCondition.cs
- ShapeTypeface.cs
- Point3DAnimation.cs
- CultureSpecificCharacterBufferRange.cs
- GcHandle.cs
- DecimalAnimationBase.cs
- HttpProfileGroupBase.cs