Code:
/ FX-1434 / FX-1434 / 1.0 / untmp / whidbey / REDBITS / ndp / fx / src / xsp / System / Web / Security / CookieProtection.cs / 1 / CookieProtection.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.Security { using System.Security.Cryptography; using System.Web.Configuration; using System.Web.Management; public enum CookieProtection { None, Validation, Encryption, All } internal class CookieProtectionHelper { internal static string Encode (CookieProtection cookieProtection, byte [] buf, int count) { if (cookieProtection == CookieProtection.All || cookieProtection == CookieProtection.Validation) { byte[] bMac = MachineKeySection.HashData (buf, null, 0, count); if (bMac == null || bMac.Length != 20) return null; if (buf.Length >= count + 20) { Buffer.BlockCopy (bMac, 0, buf, count, 20); } else { byte[] bTemp = buf; buf = new byte[count + 20]; Buffer.BlockCopy (bTemp, 0, buf, 0, count); Buffer.BlockCopy (bMac, 0, buf, count, 20); } count += 20; } if (cookieProtection == CookieProtection.All || cookieProtection == CookieProtection.Encryption) { buf = MachineKeySection.EncryptOrDecryptData (true, buf, null, 0, count); count = buf.Length; } if (count < buf.Length) { byte[] bTemp = buf; buf = new byte[count]; Buffer.BlockCopy (bTemp, 0, buf, 0, count); } return HttpServerUtility.UrlTokenEncode(buf); } internal static byte[] Decode (CookieProtection cookieProtection, string data) { byte [] buf = HttpServerUtility.UrlTokenDecode(data); if (buf == null || cookieProtection == CookieProtection.None) return buf; if (cookieProtection == CookieProtection.All || cookieProtection == CookieProtection.Encryption) { buf = MachineKeySection.EncryptOrDecryptData (false, buf, null, 0, buf.Length); if (buf == null) return null; } if (cookieProtection == CookieProtection.All || cookieProtection == CookieProtection.Validation) { ////////////////////////////////////////////////////////////////////// // Step 2: Get the MAC: Last 20 bytes if (buf.Length <= 20) return null; byte[] buf2 = new byte[buf.Length - 20]; Buffer.BlockCopy (buf, 0, buf2, 0, buf2.Length); byte[] bMac = MachineKeySection.HashData (buf2, null, 0, buf2.Length); ////////////////////////////////////////////////////////////////////// // Step 3: Make sure the MAC is correct if (bMac == null || bMac.Length != 20) return null; for (int iter = 0; iter < 20; iter++) if (bMac[iter] != buf[buf2.Length + iter]) return null; buf = buf2; } return buf; } } }
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- SystemResourceHost.cs
- InternalRelationshipCollection.cs
- _TimerThread.cs
- TraceContextRecord.cs
- FontWeightConverter.cs
- ObjRef.cs
- LinqMaximalSubtreeNominator.cs
- ErrorFormatterPage.cs
- UInt32Converter.cs
- XDeferredAxisSource.cs
- GAC.cs
- DataListItemEventArgs.cs
- ProfileGroupSettings.cs
- HtmlTableRow.cs
- WebPartConnectionsCancelVerb.cs
- QuaternionKeyFrameCollection.cs
- PathFigureCollection.cs
- HttpListenerContext.cs
- HMACSHA1.cs
- SerializationHelper.cs
- FontCollection.cs
- KeyEventArgs.cs
- CodeNamespaceImportCollection.cs
- EUCJPEncoding.cs
- ColorContext.cs
- SerializableAttribute.cs
- TextEditorMouse.cs
- WorkflowInstanceTerminatedRecord.cs
- MonitoringDescriptionAttribute.cs
- Clause.cs
- ThemeableAttribute.cs
- SchemaManager.cs
- DataFieldCollectionEditor.cs
- SizeAnimationClockResource.cs
- GridViewDeletedEventArgs.cs
- RepeatEnumerable.cs
- EnterpriseServicesHelper.cs
- FactoryMaker.cs
- ActivityBuilderHelper.cs
- figurelength.cs
- ProcessStartInfo.cs
- ProxyWebPartConnectionCollection.cs
- ParenthesizePropertyNameAttribute.cs
- FilterUserControlBase.cs
- SoapFault.cs
- LayoutEditorPart.cs
- KerberosSecurityTokenAuthenticator.cs
- AttributeData.cs
- ProfileBuildProvider.cs
- GcSettings.cs
- FormCollection.cs
- AnnotationAdorner.cs
- DayRenderEvent.cs
- ControlBindingsCollection.cs
- RequestStatusBarUpdateEventArgs.cs
- NotSupportedException.cs
- Select.cs
- ProfilePropertyNameValidator.cs
- CustomLineCap.cs
- SourceFilter.cs
- ClientCultureInfo.cs
- DataErrorValidationRule.cs
- PointUtil.cs
- XamlPoint3DCollectionSerializer.cs
- ProcessInfo.cs
- TypeValidationEventArgs.cs
- MultipleCopiesCollection.cs
- EntityTransaction.cs
- PEFileEvidenceFactory.cs
- ObsoleteAttribute.cs
- SystemIPAddressInformation.cs
- SecurityTokenResolver.cs
- InitializationEventAttribute.cs
- InputScope.cs
- DataControlFieldCollection.cs
- HealthMonitoringSectionHelper.cs
- EntityExpressionVisitor.cs
- WindowsMenu.cs
- AutomationElementIdentifiers.cs
- TcpChannelListener.cs
- ObjectSecurity.cs
- DataServiceException.cs
- MouseGesture.cs
- ProtectedProviderSettings.cs
- ReadOnlyNameValueCollection.cs
- Simplifier.cs
- TopClause.cs
- CodeSubDirectory.cs
- BinaryExpression.cs
- ImpersonationContext.cs
- ButtonColumn.cs
- MetaForeignKeyColumn.cs
- AnimationTimeline.cs
- ViewKeyConstraint.cs
- CreateUserWizardDesigner.cs
- VirtualPathUtility.cs
- GreenMethods.cs
- CodeAccessPermission.cs
- ConnectionStringSettings.cs
- SHA512Cng.cs