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
- Attribute.cs
- AutomationElement.cs
- CorrelationService.cs
- BaseContextMenu.cs
- SmtpMail.cs
- XmlILOptimizerVisitor.cs
- Number.cs
- TdsValueSetter.cs
- ListViewSortEventArgs.cs
- SapiInterop.cs
- TableCellCollection.cs
- ZipIOLocalFileBlock.cs
- SQLInt64.cs
- PlainXmlSerializer.cs
- HttpApplicationFactory.cs
- CharAnimationUsingKeyFrames.cs
- Page.cs
- PropertyDescriptorCollection.cs
- WinEventQueueItem.cs
- ImageButton.cs
- SmiEventSink_DeferedProcessing.cs
- WebBrowserHelper.cs
- SortedDictionary.cs
- PositiveTimeSpanValidatorAttribute.cs
- Unit.cs
- OleDbCommandBuilder.cs
- PingOptions.cs
- EditorAttribute.cs
- ReflectPropertyDescriptor.cs
- EmissiveMaterial.cs
- IndependentAnimationStorage.cs
- PolicyException.cs
- RenderContext.cs
- OptimizedTemplateContent.cs
- Clock.cs
- DataChangedEventManager.cs
- ApplicationInfo.cs
- ToolBarButtonDesigner.cs
- EditorZoneDesigner.cs
- EntityContainerEmitter.cs
- TypeDescriptionProvider.cs
- ColumnReorderedEventArgs.cs
- SqlDataSourceSelectingEventArgs.cs
- DataGridViewRowStateChangedEventArgs.cs
- ScriptRegistrationManager.cs
- CommandID.cs
- ManifestSignedXml.cs
- LinearGradientBrush.cs
- ColorConvertedBitmapExtension.cs
- MsmqIntegrationMessagePool.cs
- ArglessEventHandlerProxy.cs
- MissingFieldException.cs
- XmlReaderSettings.cs
- CompilerGeneratedAttribute.cs
- SHA1Managed.cs
- DataControlPagerLinkButton.cs
- ToolStripProfessionalLowResolutionRenderer.cs
- FactoryGenerator.cs
- DefinitionUpdate.cs
- ParenthesizePropertyNameAttribute.cs
- ComboBoxItem.cs
- ArrayElementGridEntry.cs
- SmiContextFactory.cs
- XmlDataDocument.cs
- DataGridColumnCollection.cs
- SymDocumentType.cs
- ToggleProviderWrapper.cs
- ContextQuery.cs
- SpeechSynthesizer.cs
- PersonalizableAttribute.cs
- _KerberosClient.cs
- ContextDataSourceView.cs
- DeploymentSection.cs
- RawStylusInputCustomDataList.cs
- StorageComplexPropertyMapping.cs
- TaskForm.cs
- TypeInitializationException.cs
- ObjectDataSource.cs
- FilterFactory.cs
- Blend.cs
- RecognizerInfo.cs
- DataSourceXmlAttributeAttribute.cs
- AddInProcess.cs
- BamlRecordHelper.cs
- ConfigurationManagerHelper.cs
- ActivityXRefPropertyEditor.cs
- recordstatescratchpad.cs
- ExternalException.cs
- ImportCatalogPart.cs
- SerializableAuthorizationContext.cs
- TripleDES.cs
- GroupDescription.cs
- UrlPath.cs
- ActivityValidationServices.cs
- SettingsPropertyIsReadOnlyException.cs
- ApplicationSecurityManager.cs
- TrailingSpaceComparer.cs
- AssemblyContextControlItem.cs
- DataControlCommands.cs
- TemplatedMailWebEventProvider.cs