Code:
/ FXUpdate3074 / FXUpdate3074 / 1.1 / DEVDIV / depot / DevDiv / releases / whidbey / QFE / 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; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //------------------------------------------------------------------------------ //// 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; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- PropertyMapper.cs
- RegexRunner.cs
- ReferenceService.cs
- ArgIterator.cs
- TailCallAnalyzer.cs
- FrameworkContextData.cs
- StoryFragments.cs
- ProfileService.cs
- CommonGetThemePartSize.cs
- ListView.cs
- ProcessHostFactoryHelper.cs
- CornerRadiusConverter.cs
- ProfileSettingsCollection.cs
- SerializationHelper.cs
- Separator.cs
- VectorKeyFrameCollection.cs
- PropertyInfoSet.cs
- XmlnsPrefixAttribute.cs
- ConfigPathUtility.cs
- ExtendedPropertyDescriptor.cs
- SafeLibraryHandle.cs
- ToolStripItemDesigner.cs
- Pair.cs
- PlainXmlSerializer.cs
- ExternalCalls.cs
- OleDbInfoMessageEvent.cs
- ManagementObjectSearcher.cs
- Link.cs
- ReaderWriterLockSlim.cs
- ValueProviderWrapper.cs
- EntityExpressionVisitor.cs
- BulletedList.cs
- StrokeSerializer.cs
- HtmlTableRowCollection.cs
- ReadWriteSpinLock.cs
- SponsorHelper.cs
- DataGridViewSelectedColumnCollection.cs
- DefaultValueAttribute.cs
- DispatcherTimer.cs
- BuilderInfo.cs
- Control.cs
- ChildChangedEventArgs.cs
- HtmlListAdapter.cs
- Color.cs
- HttpStreamMessageEncoderFactory.cs
- _ServiceNameStore.cs
- EntityDataSourceDesigner.cs
- DynamicValueConverter.cs
- CharConverter.cs
- ToolBarButton.cs
- HiddenField.cs
- NotificationContext.cs
- Listbox.cs
- SrgsDocument.cs
- Pool.cs
- WrapperSecurityCommunicationObject.cs
- FieldBuilder.cs
- __Filters.cs
- UnicastIPAddressInformationCollection.cs
- QueryUtil.cs
- InvariantComparer.cs
- ScrollChrome.cs
- SettingsPropertyValue.cs
- UInt32Storage.cs
- DataConnectionHelper.cs
- X509Certificate.cs
- HttpCookie.cs
- FromRequest.cs
- SystemWebExtensionsSectionGroup.cs
- MouseOverProperty.cs
- ServiceBuildProvider.cs
- BaseTemplateParser.cs
- COM2DataTypeToManagedDataTypeConverter.cs
- SystemSounds.cs
- Queue.cs
- ClientWindowsAuthenticationMembershipProvider.cs
- XmlArrayAttribute.cs
- MappingMetadataHelper.cs
- ResourceAssociationSetEnd.cs
- CodePageEncoding.cs
- ForwardPositionQuery.cs
- ColorMap.cs
- xdrvalidator.cs
- XslTransform.cs
- PointAnimationClockResource.cs
- Errors.cs
- WebColorConverter.cs
- XPathNavigatorException.cs
- ISCIIEncoding.cs
- SystemSounds.cs
- TypeConverterValueSerializer.cs
- SpotLight.cs
- MachineKeyConverter.cs
- MetadataFile.cs
- FontFamilyIdentifier.cs
- SelectionList.cs
- IndentedWriter.cs
- Perspective.cs
- ProcessProtocolHandler.cs
- DateTimeFormat.cs