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
- SqlParameterCollection.cs
- DataServiceResponse.cs
- PageEventArgs.cs
- BinaryObjectWriter.cs
- CutCopyPasteHelper.cs
- PropertyMetadata.cs
- StringDictionaryEditor.cs
- OdbcConnection.cs
- ImageBrush.cs
- ParameterSubsegment.cs
- ObjectViewEntityCollectionData.cs
- HitTestWithGeometryDrawingContextWalker.cs
- EntityDataSourceStatementEditor.cs
- ListBox.cs
- CodeSnippetStatement.cs
- DetailsViewPageEventArgs.cs
- SelfSignedCertificate.cs
- Brush.cs
- SessionStateItemCollection.cs
- TrackingMemoryStreamFactory.cs
- StrongNameIdentityPermission.cs
- HandleExceptionArgs.cs
- HtmlInputCheckBox.cs
- Focus.cs
- WaitHandle.cs
- CheckBoxField.cs
- control.ime.cs
- LocalizableAttribute.cs
- StylusEventArgs.cs
- TextBox.cs
- RegexCompiler.cs
- FormsAuthenticationModule.cs
- GenericTypeParameterBuilder.cs
- WorkflowMarkupSerializer.cs
- PageAdapter.cs
- DataColumnChangeEvent.cs
- AudioException.cs
- DataGridViewAddColumnDialog.cs
- SharedConnectionWorkflowTransactionService.cs
- CounterSample.cs
- COM2IDispatchConverter.cs
- HttpWrapper.cs
- EdmSchemaError.cs
- DataSourceSelectArguments.cs
- BrowserInteropHelper.cs
- NavigationPropertySingletonExpression.cs
- SimpleRecyclingCache.cs
- SmiEventStream.cs
- TimeSpanValidatorAttribute.cs
- AssemblyInfo.cs
- ConditionCollection.cs
- CounterCreationData.cs
- PolicyValidationException.cs
- BreakRecordTable.cs
- ViewGenerator.cs
- UpDownEvent.cs
- MtomMessageEncodingElement.cs
- MediaSystem.cs
- ColorConverter.cs
- FileRecordSequenceCompletedAsyncResult.cs
- ServiceBusyException.cs
- Int32Animation.cs
- QilInvoke.cs
- GacUtil.cs
- EditingScopeUndoUnit.cs
- TileBrush.cs
- X509ChainElement.cs
- TimerEventSubscriptionCollection.cs
- InvokeWebServiceDesigner.cs
- DetailsViewDeleteEventArgs.cs
- EventRouteFactory.cs
- DataGridViewCellMouseEventArgs.cs
- ResXResourceWriter.cs
- RequestCachePolicyConverter.cs
- UrlMapping.cs
- ProviderConnectionPointCollection.cs
- SQLConvert.cs
- WebRequestModulesSection.cs
- DatagridviewDisplayedBandsData.cs
- RowVisual.cs
- DataControlCommands.cs
- KerberosSecurityTokenProvider.cs
- DataGridColumnHeaderItemAutomationPeer.cs
- FloaterBaseParaClient.cs
- GeneralTransform3D.cs
- PackageProperties.cs
- CompilerCollection.cs
- SurrogateEncoder.cs
- RectAnimation.cs
- Attributes.cs
- log.cs
- RegexFCD.cs
- DecoderFallback.cs
- ActionNotSupportedException.cs
- WmfPlaceableFileHeader.cs
- SliderAutomationPeer.cs
- FontSizeConverter.cs
- DependencyProperty.cs
- EventLogPermission.cs
- FixedSOMLineCollection.cs