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
- BmpBitmapEncoder.cs
- ControlType.cs
- CompareValidator.cs
- PolicyStatement.cs
- EditorReuseAttribute.cs
- DictionaryManager.cs
- ExcludePathInfo.cs
- FormViewInsertEventArgs.cs
- BaseCodeDomTreeGenerator.cs
- Route.cs
- DefaultMemberAttribute.cs
- ConnectionManagementSection.cs
- DBSqlParserTableCollection.cs
- ComponentDispatcher.cs
- ObjectContextServiceProvider.cs
- MultiAsyncResult.cs
- TreeNodeEventArgs.cs
- SmiEventSink.cs
- TextParaClient.cs
- PrinterSettings.cs
- IResourceProvider.cs
- UIEndRequest.cs
- SoapConverter.cs
- ConfigurationPropertyAttribute.cs
- SafeCryptHandles.cs
- SqlDataSourceQueryConverter.cs
- Options.cs
- UpdateTranslator.cs
- PropagatorResult.cs
- TextParaClient.cs
- MenuCommand.cs
- TokenizerHelper.cs
- SamlAssertionKeyIdentifierClause.cs
- CodeTypeReferenceCollection.cs
- SizeAnimationBase.cs
- PartialCachingControl.cs
- InProcStateClientManager.cs
- FontFamilyValueSerializer.cs
- OledbConnectionStringbuilder.cs
- Panel.cs
- FileDialog.cs
- LineVisual.cs
- ListControl.cs
- URI.cs
- XmlWhitespace.cs
- BindingContext.cs
- BamlResourceDeserializer.cs
- SortKey.cs
- HwndTarget.cs
- PriorityBindingExpression.cs
- TextEditorThreadLocalStore.cs
- ComponentResourceKey.cs
- GlyphRun.cs
- XmlQualifiedName.cs
- DataReaderContainer.cs
- GestureRecognitionResult.cs
- CustomErrorsSection.cs
- TextControlDesigner.cs
- DrawingGroupDrawingContext.cs
- Blend.cs
- ItemsPanelTemplate.cs
- webproxy.cs
- ColumnWidthChangedEvent.cs
- MediaElement.cs
- ProtectedConfigurationSection.cs
- ElementHostAutomationPeer.cs
- CompositionCommandSet.cs
- StyleSelector.cs
- CellTreeNode.cs
- MetadataConversionError.cs
- ReturnValue.cs
- FixedDocumentPaginator.cs
- PersonalizationProviderHelper.cs
- PostBackOptions.cs
- EntityModelBuildProvider.cs
- TextureBrush.cs
- DnsCache.cs
- XmlNullResolver.cs
- webeventbuffer.cs
- SqlInternalConnection.cs
- SchemaCompiler.cs
- RegexGroupCollection.cs
- BitSet.cs
- MessageBox.cs
- SafeMILHandle.cs
- ExpressionLexer.cs
- Point4DConverter.cs
- StreamReader.cs
- Point3D.cs
- SlotInfo.cs
- Path.cs
- ContainerAction.cs
- RelOps.cs
- DoubleStorage.cs
- externdll.cs
- PolyLineSegment.cs
- Baml2006KnownTypes.cs
- XmlImplementation.cs
- SqlParameterizer.cs
- PropertyValueUIItem.cs