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
- TranslateTransform.cs
- GroupStyle.cs
- ZoomingMessageFilter.cs
- GlobalEventManager.cs
- RequestSecurityTokenResponse.cs
- cookieexception.cs
- ObjectCloneHelper.cs
- DESCryptoServiceProvider.cs
- LicenseManager.cs
- ReceiveReply.cs
- KnownAssembliesSet.cs
- WindowPatternIdentifiers.cs
- OperationAbortedException.cs
- ArglessEventHandlerProxy.cs
- DataGridViewTextBoxCell.cs
- VirtualPath.cs
- ClientConfigurationHost.cs
- GeometryValueSerializer.cs
- OracleFactory.cs
- ExternalCalls.cs
- PartBasedPackageProperties.cs
- CredentialSelector.cs
- ParameterDataSourceExpression.cs
- Activity.cs
- DocumentsTrace.cs
- Message.cs
- WebControl.cs
- OperandQuery.cs
- InkCanvasInnerCanvas.cs
- DataSourceXmlClassAttribute.cs
- TextTreeRootNode.cs
- BroadcastEventHelper.cs
- TableRowCollection.cs
- dataobject.cs
- _ListenerResponseStream.cs
- FontFamilyValueSerializer.cs
- OutputScope.cs
- DetailsView.cs
- _DigestClient.cs
- TransformedBitmap.cs
- DiscoveryRequestHandler.cs
- RowToParametersTransformer.cs
- StorageModelBuildProvider.cs
- ObjectDataSourceView.cs
- ValidationRule.cs
- ConnectionStringsExpressionBuilder.cs
- QueryPageSettingsEventArgs.cs
- ToolStripItemGlyph.cs
- Vector3D.cs
- TextTreeTextBlock.cs
- OdbcParameterCollection.cs
- JavascriptXmlWriterWrapper.cs
- WindowsTokenRoleProvider.cs
- PipeStream.cs
- Baml2006SchemaContext.cs
- TransformValueSerializer.cs
- ListenDesigner.cs
- KnownIds.cs
- JpegBitmapEncoder.cs
- EmptyQuery.cs
- XmlConvert.cs
- MemoryMappedView.cs
- TypeElement.cs
- SettingsAttributes.cs
- ProcessModuleCollection.cs
- ToolStripControlHost.cs
- CodeTypeMember.cs
- DataServiceEntityAttribute.cs
- InternalSafeNativeMethods.cs
- wmiprovider.cs
- XmlArrayItemAttributes.cs
- ObjectViewFactory.cs
- Task.cs
- DigestComparer.cs
- WebBrowserBase.cs
- HScrollBar.cs
- CheckBox.cs
- ObsoleteAttribute.cs
- OrCondition.cs
- OnOperation.cs
- PropertyMappingExceptionEventArgs.cs
- ItemsControlAutomationPeer.cs
- XmlRootAttribute.cs
- Cursor.cs
- TokenBasedSet.cs
- DeviceSpecificChoice.cs
- TypeToStringValueConverter.cs
- RenderDataDrawingContext.cs
- DNS.cs
- EditorZone.cs
- SingleTagSectionHandler.cs
- XmlAtomicValue.cs
- XmlPropertyBag.cs
- RootAction.cs
- AutomationProperties.cs
- BackoffTimeoutHelper.cs
- CombinedTcpChannel.cs
- SqlFunctionAttribute.cs
- SubstitutionList.cs
- ListViewInsertedEventArgs.cs