Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / 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
- SqlDataSourceConnectionPanel.cs
- InputBindingCollection.cs
- TimeStampChecker.cs
- PublisherIdentityPermission.cs
- TypeUsageBuilder.cs
- RectangleHotSpot.cs
- SaveCardRequest.cs
- WriteableBitmap.cs
- FrugalList.cs
- MobileErrorInfo.cs
- MemberAccessException.cs
- CapabilitiesAssignment.cs
- XPathQueryGenerator.cs
- TextBox.cs
- BamlRecords.cs
- ReceiveSecurityHeader.cs
- AnalyzedTree.cs
- HttpClientCertificate.cs
- CodeAccessSecurityEngine.cs
- QuaternionAnimation.cs
- SqlServices.cs
- ServiceBusyException.cs
- ApplicationFileParser.cs
- XmlStrings.cs
- FixedPageProcessor.cs
- StatusBar.cs
- X500Name.cs
- _NegoStream.cs
- ObjectQueryProvider.cs
- WindowsFormsEditorServiceHelper.cs
- Typeface.cs
- ConfigurationException.cs
- NegationPusher.cs
- FilterException.cs
- PriorityBinding.cs
- ColumnWidthChangingEvent.cs
- TextFragmentEngine.cs
- SchemaTypeEmitter.cs
- SQLString.cs
- System.Data_BID.cs
- EndpointDispatcherTable.cs
- _NestedMultipleAsyncResult.cs
- LookupBindingPropertiesAttribute.cs
- BindingList.cs
- TextEditorContextMenu.cs
- QueryContinueDragEventArgs.cs
- PackagingUtilities.cs
- HttpRequest.cs
- IndexingContentUnit.cs
- TextRangeProviderWrapper.cs
- HMACMD5.cs
- WebSysDescriptionAttribute.cs
- OrthographicCamera.cs
- Evidence.cs
- AdPostCacheSubstitution.cs
- MessageDesigner.cs
- Effect.cs
- SqlDelegatedTransaction.cs
- SupportingTokenSpecification.cs
- SingleAnimationUsingKeyFrames.cs
- ConnectionsZone.cs
- Style.cs
- StringUtil.cs
- QueryCreatedEventArgs.cs
- BamlBinaryWriter.cs
- TemplatedMailWebEventProvider.cs
- TypeConverterValueSerializer.cs
- Selection.cs
- TraceHandlerErrorFormatter.cs
- TypeInfo.cs
- SessionEndingEventArgs.cs
- HierarchicalDataBoundControl.cs
- QilTypeChecker.cs
- OdbcInfoMessageEvent.cs
- OutputCacheModule.cs
- ServiceEndpointCollection.cs
- AutomationPattern.cs
- ReliabilityContractAttribute.cs
- RenderDataDrawingContext.cs
- Int32CAMarshaler.cs
- DesignerActionKeyboardBehavior.cs
- CfgArc.cs
- ColorContext.cs
- UnsafeNetInfoNativeMethods.cs
- DateTimeConstantAttribute.cs
- FontUnitConverter.cs
- ClientRolePrincipal.cs
- EventlogProvider.cs
- DomainUpDown.cs
- FloatAverageAggregationOperator.cs
- BindableAttribute.cs
- base64Transforms.cs
- BuildProvidersCompiler.cs
- Viewport2DVisual3D.cs
- MultiDataTrigger.cs
- XmlMembersMapping.cs
- TextMetrics.cs
- AutomationPattern.cs
- BitStream.cs
- ExpandCollapseProviderWrapper.cs