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
- ParameterCollection.cs
- FontFamilyConverter.cs
- DbProviderSpecificTypePropertyAttribute.cs
- BufferCache.cs
- WindowsBrush.cs
- DurableInstanceProvider.cs
- Camera.cs
- FlowchartStart.xaml.cs
- HandlerFactoryCache.cs
- QfeChecker.cs
- VariableBinder.cs
- StreamUpdate.cs
- IgnoreDeviceFilterElementCollection.cs
- EventlogProvider.cs
- TextAutomationPeer.cs
- ExtentJoinTreeNode.cs
- ServiceHandle.cs
- TagPrefixInfo.cs
- ExceptionHelpers.cs
- XmlAttributeProperties.cs
- CodeConditionStatement.cs
- TableItemPatternIdentifiers.cs
- ReadOnlyTernaryTree.cs
- SafeBuffer.cs
- ClientScriptItemCollection.cs
- AuthorizationRule.cs
- ConfigXmlDocument.cs
- SerTrace.cs
- BrushValueSerializer.cs
- PropertyToken.cs
- DataGridViewCell.cs
- Utils.cs
- DoubleCollection.cs
- GlyphTypeface.cs
- WorkflowOwnershipException.cs
- ParserHooks.cs
- FontNamesConverter.cs
- WindowsRichEditRange.cs
- XmlSchemaExporter.cs
- ValueTable.cs
- XmlElementList.cs
- DataList.cs
- SerialReceived.cs
- XmlSerializerFaultFormatter.cs
- TokenBasedSet.cs
- TreeNodeStyleCollectionEditor.cs
- ControlLocalizer.cs
- TextRangeAdaptor.cs
- AttributedMetaModel.cs
- StackBuilderSink.cs
- PipelineModuleStepContainer.cs
- HttpFileCollectionWrapper.cs
- XmlNodeComparer.cs
- HierarchicalDataBoundControlAdapter.cs
- BlockUIContainer.cs
- UIElementPropertyUndoUnit.cs
- CopyOnWriteList.cs
- ActivityWithResultWrapper.cs
- WindowsUpDown.cs
- TextDecorationCollection.cs
- DBBindings.cs
- BamlResourceDeserializer.cs
- UntrustedRecipientException.cs
- SQLDouble.cs
- Utils.cs
- XmlReflectionMember.cs
- TextSearch.cs
- DataGridViewRowPrePaintEventArgs.cs
- FindCriteriaElement.cs
- _MultipleConnectAsync.cs
- ChainedAsyncResult.cs
- ToolboxComponentsCreatedEventArgs.cs
- X509AudioLogo.cs
- GeneralTransform2DTo3D.cs
- HotSpot.cs
- CompilerScope.Storage.cs
- webproxy.cs
- ConfigurationSectionGroup.cs
- _ListenerAsyncResult.cs
- UIElementIsland.cs
- SqlCacheDependencyDatabaseCollection.cs
- EnvelopedPkcs7.cs
- WebBrowserNavigatedEventHandler.cs
- QilIterator.cs
- TextServicesDisplayAttributePropertyRanges.cs
- DropDownList.cs
- PageVisual.cs
- ResourcePart.cs
- ToolStripOverflowButton.cs
- ToolStripGripRenderEventArgs.cs
- ViewCellSlot.cs
- UserControlDesigner.cs
- ProtectedConfigurationProviderCollection.cs
- WindowsComboBox.cs
- DataExpression.cs
- CopyOfAction.cs
- PreservationFileReader.cs
- RelationshipConstraintValidator.cs
- BinaryObjectInfo.cs
- PanelContainerDesigner.cs