Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / 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. // //----------------------------------------------------------------------------- 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.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ListViewItem.cs
- XamlStyleSerializer.cs
- X509SecurityTokenAuthenticator.cs
- FrameworkRichTextComposition.cs
- odbcmetadatacollectionnames.cs
- Cursors.cs
- HttpModuleAction.cs
- PerformanceCounterPermissionEntryCollection.cs
- XamlSerializerUtil.cs
- Visitors.cs
- LinkArea.cs
- InteropTrackingRecord.cs
- Variant.cs
- SafeRightsManagementSessionHandle.cs
- WizardStepBase.cs
- SmtpFailedRecipientsException.cs
- ConfigurationStrings.cs
- MenuItemBinding.cs
- WebBrowserNavigatingEventHandler.cs
- LinkConverter.cs
- Completion.cs
- ValueUtilsSmi.cs
- Size3DConverter.cs
- DependencyPropertyKey.cs
- XslTransformFileEditor.cs
- EpmCustomContentSerializer.cs
- EmbeddedObject.cs
- ConfigurationElementProperty.cs
- DataRecord.cs
- printdlgexmarshaler.cs
- View.cs
- CheckBoxRenderer.cs
- CollaborationHelperFunctions.cs
- DictionaryEntry.cs
- ApplicationBuildProvider.cs
- RegexFCD.cs
- SpoolingTaskBase.cs
- CompositeTypefaceMetrics.cs
- IndexerNameAttribute.cs
- XmlSerializableWriter.cs
- WebBaseEventKeyComparer.cs
- TextTreeRootNode.cs
- NativeRightsManagementAPIsStructures.cs
- SafeRightsManagementPubHandle.cs
- SqlNodeTypeOperators.cs
- StringConverter.cs
- MbpInfo.cs
- DataComponentNameHandler.cs
- UniqueEventHelper.cs
- WebServiceMethodData.cs
- AdPostCacheSubstitution.cs
- SystemIPAddressInformation.cs
- XmlSchemaAll.cs
- SecureUICommand.cs
- DataGridViewCellConverter.cs
- ArrayList.cs
- LinearQuaternionKeyFrame.cs
- ProxyWebPart.cs
- CommandID.cs
- StateMachine.cs
- PreviewControlDesigner.cs
- WizardDesigner.cs
- AttachedPropertyBrowsableWhenAttributePresentAttribute.cs
- ValidateNames.cs
- ListArgumentProvider.cs
- ManagedIStream.cs
- UnsafeNativeMethods.cs
- DecimalKeyFrameCollection.cs
- IssuedTokenClientElement.cs
- WebPartRestoreVerb.cs
- AssociationEndMember.cs
- CompilationLock.cs
- WebPartsSection.cs
- WindowsTooltip.cs
- ProtocolsConfiguration.cs
- DocumentApplicationJournalEntry.cs
- TextSchema.cs
- DesignerTransactionCloseEvent.cs
- DependencyObject.cs
- WeakReferenceKey.cs
- TextPatternIdentifiers.cs
- DebugView.cs
- GridProviderWrapper.cs
- PreservationFileWriter.cs
- SQLMoneyStorage.cs
- JoinElimination.cs
- SessionStateUtil.cs
- HuffCodec.cs
- WinFormsSecurity.cs
- MediaSystem.cs
- NetCodeGroup.cs
- MemberHolder.cs
- FunctionImportMapping.ReturnTypeRenameMapping.cs
- OdbcConnectionString.cs
- AudioFormatConverter.cs
- InitiatorServiceModelSecurityTokenRequirement.cs
- SqlXml.cs
- GetPageNumberCompletedEventArgs.cs
- EdmItemCollection.cs
- ProviderCommandInfoUtils.cs