Code:
/ FXUpdate3074 / FXUpdate3074 / 1.1 / untmp / 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.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- UnsafeNativeMethods.cs
- XomlCompilerParameters.cs
- Stackframe.cs
- DescendantOverDescendantQuery.cs
- ImageIndexEditor.cs
- InvalidMessageContractException.cs
- VisualTarget.cs
- ConsumerConnectionPoint.cs
- CheckedListBox.cs
- ApplyHostConfigurationBehavior.cs
- UnionCodeGroup.cs
- AvTraceDetails.cs
- WebBrowser.cs
- TransactionFlowOption.cs
- UrlAuthorizationModule.cs
- ResourceExpressionEditorSheet.cs
- DockEditor.cs
- RequestTimeoutManager.cs
- PersistNameAttribute.cs
- TrailingSpaceComparer.cs
- HashCodeCombiner.cs
- DoubleAnimationUsingPath.cs
- SymmetricAlgorithm.cs
- FileLevelControlBuilderAttribute.cs
- EpmCustomContentSerializer.cs
- ComponentCollection.cs
- ChannelFactory.cs
- SessionStateModule.cs
- TextEndOfParagraph.cs
- TypeExtensionConverter.cs
- ListParaClient.cs
- Separator.cs
- TextPenaltyModule.cs
- JournalNavigationScope.cs
- OdbcCommand.cs
- AliasExpr.cs
- HostingEnvironmentSection.cs
- Utils.cs
- SrgsRuleRef.cs
- RouteData.cs
- EnumValAlphaComparer.cs
- SerializationObjectManager.cs
- DataGridViewCell.cs
- FormView.cs
- ObjectNavigationPropertyMapping.cs
- TraceAsyncResult.cs
- RSACryptoServiceProvider.cs
- DelimitedListTraceListener.cs
- XmlSchemaSimpleType.cs
- ContextMenuStripGroupCollection.cs
- AmbientEnvironment.cs
- Token.cs
- QilExpression.cs
- DurableServiceAttribute.cs
- WebRequestModuleElement.cs
- MenuDesigner.cs
- ScaleTransform.cs
- TerminatorSinks.cs
- CodeTypeDelegate.cs
- StrokeNodeOperations.cs
- MsmqChannelListenerBase.cs
- IUnknownConstantAttribute.cs
- DeviceContext2.cs
- PersonalizationProviderHelper.cs
- BulletChrome.cs
- LinkButton.cs
- IQueryable.cs
- MultipartIdentifier.cs
- PermissionListSet.cs
- HostingEnvironmentSection.cs
- XmlBaseWriter.cs
- InplaceBitmapMetadataWriter.cs
- SystemBrushes.cs
- TreeIterator.cs
- FixedDSBuilder.cs
- RequiredAttributeAttribute.cs
- HttpApplication.cs
- DispatchChannelSink.cs
- EntityCommandDefinition.cs
- HashSetDebugView.cs
- LinkTarget.cs
- SignatureHelper.cs
- CompoundFileStreamReference.cs
- MoveSizeWinEventHandler.cs
- TraceHandlerErrorFormatter.cs
- XmlNavigatorStack.cs
- DoubleAnimationUsingPath.cs
- BaseCodePageEncoding.cs
- AvTraceDetails.cs
- HostProtectionException.cs
- SharedUtils.cs
- InvokeWebService.cs
- SplitterCancelEvent.cs
- CompleteWizardStep.cs
- QilPatternVisitor.cs
- PersonalizationAdministration.cs
- UnauthorizedAccessException.cs
- ResourcesChangeInfo.cs
- BooleanConverter.cs
- RegexCapture.cs