Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / 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
- XamlReader.cs
- RelationshipNavigation.cs
- XPathQilFactory.cs
- DeferredElementTreeState.cs
- ProcessThreadCollection.cs
- PageClientProxyGenerator.cs
- TagNameToTypeMapper.cs
- HttpModuleAction.cs
- TemplateBaseAction.cs
- IsolatedStorageFilePermission.cs
- JsonFormatGeneratorStatics.cs
- WizardStepBase.cs
- DefaultTraceListener.cs
- DispatchChannelSink.cs
- IndentedTextWriter.cs
- MetadataArtifactLoaderFile.cs
- EditorOptionAttribute.cs
- PointKeyFrameCollection.cs
- CompressEmulationStream.cs
- BaseDataListDesigner.cs
- DataGridViewTopLeftHeaderCell.cs
- CultureInfoConverter.cs
- MultiBinding.cs
- StreamFormatter.cs
- IOThreadTimer.cs
- NegotiateStream.cs
- VoiceObjectToken.cs
- SqlTypeConverter.cs
- ParserExtension.cs
- CodeDirectionExpression.cs
- HttpListenerTimeoutManager.cs
- XmlNodeChangedEventArgs.cs
- ButtonBaseDesigner.cs
- TraceSource.cs
- Vector3DIndependentAnimationStorage.cs
- QilXmlReader.cs
- BindingMAnagerBase.cs
- AlternateViewCollection.cs
- HttpWebRequest.cs
- DataGridViewSelectedRowCollection.cs
- GridViewCommandEventArgs.cs
- GenericTextProperties.cs
- LassoSelectionBehavior.cs
- SmtpCommands.cs
- LineInfo.cs
- AttributeProviderAttribute.cs
- CodeNamespaceImport.cs
- StyleSheetRefUrlEditor.cs
- FixedTextContainer.cs
- CheckBoxAutomationPeer.cs
- HttpConfigurationSystem.cs
- ItemsControlAutomationPeer.cs
- mediaeventargs.cs
- UnionQueryOperator.cs
- UpdateExpressionVisitor.cs
- ListBase.cs
- DashStyle.cs
- WebUtility.cs
- AsyncStreamReader.cs
- SeekStoryboard.cs
- Calendar.cs
- EntityModelBuildProvider.cs
- QilLiteral.cs
- DockPanel.cs
- XmlSchemaRedefine.cs
- BehaviorDragDropEventArgs.cs
- GridViewRow.cs
- WebPageTraceListener.cs
- ScriptManagerProxy.cs
- TraceSection.cs
- AuthenticatedStream.cs
- RootDesignerSerializerAttribute.cs
- EnumMember.cs
- StorageInfo.cs
- PackageRelationshipCollection.cs
- CompareValidator.cs
- VirtualizedContainerService.cs
- SqlError.cs
- WebServiceReceiveDesigner.cs
- MenuRenderer.cs
- NotFiniteNumberException.cs
- SizeValueSerializer.cs
- DataPagerFieldCollection.cs
- TypeContext.cs
- ControlSerializer.cs
- RtfToXamlLexer.cs
- HandleCollector.cs
- SqlDataSourceSelectingEventArgs.cs
- DataGridViewCellEventArgs.cs
- WpfKnownType.cs
- LoadedEvent.cs
- LogExtent.cs
- BitmapSource.cs
- BreakRecordTable.cs
- CopyNamespacesAction.cs
- OutputScopeManager.cs
- SubpageParaClient.cs
- _FtpDataStream.cs
- WebConfigurationFileMap.cs
- ControlTemplate.cs