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
- UnsafeNetInfoNativeMethods.cs
- JoinTreeNode.cs
- TextRange.cs
- XmlArrayItemAttributes.cs
- MDIClient.cs
- Root.cs
- RichListBox.cs
- GroupBox.cs
- BasicExpandProvider.cs
- SafeTimerHandle.cs
- FilteredXmlReader.cs
- WSHttpSecurityElement.cs
- DataKeyCollection.cs
- AlternationConverter.cs
- RtType.cs
- NativeCppClassAttribute.cs
- LocalizabilityAttribute.cs
- ExceptionUtil.cs
- DescendantOverDescendantQuery.cs
- IIS7WorkerRequest.cs
- SplitterEvent.cs
- VerificationAttribute.cs
- X509Certificate2Collection.cs
- GridViewColumnHeader.cs
- DockProviderWrapper.cs
- CookielessData.cs
- FuncCompletionCallbackWrapper.cs
- ImageFormatConverter.cs
- BuilderPropertyEntry.cs
- NavigationExpr.cs
- IISUnsafeMethods.cs
- WindowsSecurityToken.cs
- EtwTrace.cs
- DataControlFieldsEditor.cs
- MeshGeometry3D.cs
- NativeWindow.cs
- Bezier.cs
- RectangleGeometry.cs
- VideoDrawing.cs
- SequentialUshortCollection.cs
- Bits.cs
- SqlDataSourceView.cs
- PrtTicket_Base.cs
- PathFigureCollectionConverter.cs
- DesignSurfaceCollection.cs
- BitmapVisualManager.cs
- EnvironmentPermission.cs
- Base64WriteStateInfo.cs
- TextTreeUndoUnit.cs
- TaskExtensions.cs
- LinqDataSourceView.cs
- TransformGroup.cs
- SqlDataSourceConfigureSortForm.cs
- CompilationAssemblyInstallComponent.cs
- assemblycache.cs
- DesignerLoader.cs
- SQLChars.cs
- EndpointInstanceProvider.cs
- NestPullup.cs
- ButtonColumn.cs
- MSHTMLHost.cs
- MemberMemberBinding.cs
- PageParser.cs
- MDIControlStrip.cs
- TimeSpanSecondsOrInfiniteConverter.cs
- FontUnitConverter.cs
- ConnectionsZone.cs
- DynamicResourceExtensionConverter.cs
- CellParagraph.cs
- RegexCharClass.cs
- ImageConverter.cs
- _ProxyChain.cs
- XmlDataSourceView.cs
- ImageField.cs
- DbParameterCollectionHelper.cs
- DelayedRegex.cs
- ScriptingWebServicesSectionGroup.cs
- NavigatorOutput.cs
- DynamicFilterExpression.cs
- WindowsScroll.cs
- MultilineStringConverter.cs
- ObjectContext.cs
- XmlElementElementCollection.cs
- PathSegmentCollection.cs
- WebAdminConfigurationHelper.cs
- VectorAnimationBase.cs
- XPathNode.cs
- httpapplicationstate.cs
- TableColumnCollection.cs
- SqlNotificationRequest.cs
- MessageBuffer.cs
- DetailsViewInsertEventArgs.cs
- Quaternion.cs
- ClickablePoint.cs
- SizeConverter.cs
- QueueException.cs
- MemberAssignment.cs
- hebrewshape.cs
- CollectionChangedEventManager.cs
- Msec.cs