Code:
/ FX-1434 / FX-1434 / 1.0 / untmp / whidbey / REDBITS / 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; } } }
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- IndentedWriter.cs
- _NegotiateClient.cs
- RadioButton.cs
- DbConnectionStringBuilder.cs
- XPathNodeIterator.cs
- ReverseComparer.cs
- peernodeimplementation.cs
- TextAdaptor.cs
- DiscoveryInnerClientManaged11.cs
- DataExpression.cs
- BrushValueSerializer.cs
- XpsFontSerializationService.cs
- TargetFrameworkAttribute.cs
- InlineObject.cs
- HideDisabledControlAdapter.cs
- VerifyHashRequest.cs
- BooleanAnimationBase.cs
- SmiConnection.cs
- EdmProperty.cs
- TableRowCollection.cs
- XmlExpressionDumper.cs
- RegexParser.cs
- MissingManifestResourceException.cs
- LightweightCodeGenerator.cs
- DbProviderManifest.cs
- EdmProviderManifest.cs
- ExpressionEditorAttribute.cs
- MessageAction.cs
- TransportContext.cs
- XPathCompileException.cs
- CreateUserWizard.cs
- VBIdentifierTrimConverter.cs
- QilTypeChecker.cs
- IndexingContentUnit.cs
- MenuBase.cs
- HostingEnvironment.cs
- RuleRefElement.cs
- SqlUnionizer.cs
- DoubleStorage.cs
- AsymmetricSignatureDeformatter.cs
- DataGridViewButtonColumn.cs
- MsmqProcessProtocolHandler.cs
- ToolCreatedEventArgs.cs
- SID.cs
- DataMemberConverter.cs
- MasterPageCodeDomTreeGenerator.cs
- InfoCardRequestException.cs
- SafeLibraryHandle.cs
- StorageSetMapping.cs
- KeyGestureConverter.cs
- Pkcs7Signer.cs
- RawAppCommandInputReport.cs
- RoutedEventArgs.cs
- ProgressBarAutomationPeer.cs
- GeometryCollection.cs
- KeyValuePair.cs
- MULTI_QI.cs
- XamlInt32CollectionSerializer.cs
- FlowNode.cs
- WebUtil.cs
- SByteConverter.cs
- ZoneMembershipCondition.cs
- DispatcherSynchronizationContext.cs
- LongValidator.cs
- MenuItemCollection.cs
- SortQuery.cs
- Translator.cs
- RelationshipEnd.cs
- _ServiceNameStore.cs
- NumberFormatInfo.cs
- MemberCollection.cs
- _NestedMultipleAsyncResult.cs
- SettingsPropertyNotFoundException.cs
- ActivationProxy.cs
- CalendarSelectionChangedEventArgs.cs
- TransformerInfoCollection.cs
- LoginCancelEventArgs.cs
- DbgCompiler.cs
- ClrPerspective.cs
- QilStrConcatenator.cs
- DbExpressionVisitor.cs
- QilXmlWriter.cs
- BufferModeSettings.cs
- WizardPanel.cs
- SerializationEventsCache.cs
- RegexMatch.cs
- TextElementCollection.cs
- WebBrowserNavigatedEventHandler.cs
- ClientScriptManagerWrapper.cs
- ErasingStroke.cs
- GridToolTip.cs
- SafeNativeMethods.cs
- CompilerLocalReference.cs
- PagePropertiesChangingEventArgs.cs
- TreeNodeStyle.cs
- MemberRestriction.cs
- RouteValueDictionary.cs
- JavaScriptString.cs
- DbModificationCommandTree.cs
- ListViewGroupItemCollection.cs