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
- AsyncCodeActivityContext.cs
- NavigateEvent.cs
- TransformerInfo.cs
- WebBrowserUriTypeConverter.cs
- GridEntry.cs
- XsltArgumentList.cs
- EventLogQuery.cs
- PeekCompletedEventArgs.cs
- Converter.cs
- Utils.cs
- Attributes.cs
- GeometryHitTestParameters.cs
- WindowPatternIdentifiers.cs
- PreDigestedSignedInfo.cs
- MailHeaderInfo.cs
- GridErrorDlg.cs
- DebugHandleTracker.cs
- SqlDependencyListener.cs
- BufferedGraphics.cs
- XmlTextReaderImpl.cs
- PersonalizationEntry.cs
- DictionaryBase.cs
- UriWriter.cs
- HttpResponseWrapper.cs
- Selection.cs
- LayoutManager.cs
- WinEventWrap.cs
- JumpItem.cs
- CallSite.cs
- DataMisalignedException.cs
- XmlSchemaValidator.cs
- MsmqHostedTransportManager.cs
- SingleObjectCollection.cs
- MediaTimeline.cs
- UriTemplateTrieNode.cs
- MouseOverProperty.cs
- StringValueConverter.cs
- LineServices.cs
- DefinitionProperties.cs
- DataRecordInternal.cs
- SerialPort.cs
- DataGridViewRowContextMenuStripNeededEventArgs.cs
- VideoDrawing.cs
- TextAction.cs
- ToolStripLocationCancelEventArgs.cs
- XmlSchemaCompilationSettings.cs
- PublisherMembershipCondition.cs
- CqlParser.cs
- XMLDiffLoader.cs
- CleanUpVirtualizedItemEventArgs.cs
- LicenseContext.cs
- recordstatefactory.cs
- ScopedKnownTypes.cs
- ExceptQueryOperator.cs
- ISSmlParser.cs
- HtmlInputControl.cs
- QilNode.cs
- Annotation.cs
- DataMember.cs
- UpdateCommand.cs
- BitArray.cs
- ColumnMapVisitor.cs
- InstanceNormalEvent.cs
- EncoderNLS.cs
- ObjectDataSourceWizardForm.cs
- Int64AnimationBase.cs
- SpoolingTask.cs
- HttpRequestTraceRecord.cs
- XamlLoadErrorInfo.cs
- Splitter.cs
- CodeLabeledStatement.cs
- AccessDataSource.cs
- EntityDataSourceWrapper.cs
- TagPrefixCollection.cs
- ComponentDispatcherThread.cs
- StylusPointPropertyId.cs
- Peer.cs
- ButtonBaseAutomationPeer.cs
- TransformerConfigurationWizardBase.cs
- ContainerUtilities.cs
- XPathNodeInfoAtom.cs
- DebuggerAttributes.cs
- ColumnWidthChangingEvent.cs
- RectAnimationClockResource.cs
- SQLRoleProvider.cs
- WinEventTracker.cs
- FakeModelItemImpl.cs
- ObfuscateAssemblyAttribute.cs
- HyperLinkField.cs
- FileDialogPermission.cs
- CacheVirtualItemsEvent.cs
- ChineseLunisolarCalendar.cs
- _AcceptOverlappedAsyncResult.cs
- SqlCacheDependencyDatabaseCollection.cs
- SynchronizationLockException.cs
- ExpressionNode.cs
- WebPart.cs
- DnsPermission.cs
- ClientConfigPaths.cs
- KeyBinding.cs