Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / clr / src / BCL / System / Security / Cryptography / TripleDES.cs / 1 / TripleDES.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== // // TripleDES.cs // namespace System.Security.Cryptography { [System.Runtime.InteropServices.ComVisible(true)] public abstract class TripleDES : SymmetricAlgorithm { private static KeySizes[] s_legalBlockSizes = { new KeySizes(64, 64, 0) }; private static KeySizes[] s_legalKeySizes = { new KeySizes(2*64, 3*64, 64) }; // // protected constructors // protected TripleDES() { KeySizeValue = 3*64; BlockSizeValue = 64; FeedbackSizeValue = BlockSizeValue; LegalBlockSizesValue = s_legalBlockSizes; LegalKeySizesValue = s_legalKeySizes; } // // public properties // public override byte[] Key { get { if (KeyValue == null) { // Never hand back a weak key do { GenerateKey(); } while (IsWeakKey(KeyValue)); } return (byte[]) KeyValue.Clone(); } set { if (value == null) throw new ArgumentNullException("value"); if (!ValidKeySize(value.Length * 8)) { // must convert bytes to bits throw new CryptographicException(Environment.GetResourceString("Cryptography_InvalidKeySize")); } if (IsWeakKey(value)) { throw new CryptographicException(Environment.GetResourceString("Cryptography_InvalidKey_Weak"),"TripleDES"); } KeyValue = (byte[]) value.Clone(); KeySizeValue = value.Length * 8; } } // // public methods // new static public TripleDES Create() { return Create("System.Security.Cryptography.TripleDES"); } new static public TripleDES Create(String str) { return (TripleDES) CryptoConfig.CreateFromName(str); } public static bool IsWeakKey(byte[] rgbKey) { // All we have to check for here is (a) we're in 3-key mode (192 bits), and // (b) either K1 == K2 or K2 == K3 if (!IsLegalKeySize(rgbKey)) { throw new CryptographicException(Environment.GetResourceString("Cryptography_InvalidKeySize")); } byte[] rgbOddParityKey = Utils.FixupKeyParity(rgbKey); if (EqualBytes(rgbOddParityKey,0,8,8)) return(true); if ((rgbOddParityKey.Length == 24) && EqualBytes(rgbOddParityKey,8,16,8)) return(true); return(false); } // // private methods // private static bool EqualBytes(byte[] rgbKey, int start1, int start2, int count) { if (start1 < 0) throw new ArgumentOutOfRangeException("start1", Environment.GetResourceString("ArgumentOutOfRange_NeedNonNegNum")); if (start2 < 0) throw new ArgumentOutOfRangeException("start2", Environment.GetResourceString("ArgumentOutOfRange_NeedNonNegNum")); if ((start1+count) > rgbKey.Length) throw new ArgumentException(Environment.GetResourceString("Argument_InvalidValue")); if ((start2+count) > rgbKey.Length) throw new ArgumentException(Environment.GetResourceString("Argument_InvalidValue")); for (int i = 0; i < count; i++) { if (rgbKey[start1+i] != rgbKey[start2+i]) return(false); } return(true); } private static bool IsLegalKeySize(byte[] rgbKey) { if (rgbKey != null && ((rgbKey.Length == 16) || (rgbKey.Length == 24))) return(true); return(false); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== // // TripleDES.cs // namespace System.Security.Cryptography { [System.Runtime.InteropServices.ComVisible(true)] public abstract class TripleDES : SymmetricAlgorithm { private static KeySizes[] s_legalBlockSizes = { new KeySizes(64, 64, 0) }; private static KeySizes[] s_legalKeySizes = { new KeySizes(2*64, 3*64, 64) }; // // protected constructors // protected TripleDES() { KeySizeValue = 3*64; BlockSizeValue = 64; FeedbackSizeValue = BlockSizeValue; LegalBlockSizesValue = s_legalBlockSizes; LegalKeySizesValue = s_legalKeySizes; } // // public properties // public override byte[] Key { get { if (KeyValue == null) { // Never hand back a weak key do { GenerateKey(); } while (IsWeakKey(KeyValue)); } return (byte[]) KeyValue.Clone(); } set { if (value == null) throw new ArgumentNullException("value"); if (!ValidKeySize(value.Length * 8)) { // must convert bytes to bits throw new CryptographicException(Environment.GetResourceString("Cryptography_InvalidKeySize")); } if (IsWeakKey(value)) { throw new CryptographicException(Environment.GetResourceString("Cryptography_InvalidKey_Weak"),"TripleDES"); } KeyValue = (byte[]) value.Clone(); KeySizeValue = value.Length * 8; } } // // public methods // new static public TripleDES Create() { return Create("System.Security.Cryptography.TripleDES"); } new static public TripleDES Create(String str) { return (TripleDES) CryptoConfig.CreateFromName(str); } public static bool IsWeakKey(byte[] rgbKey) { // All we have to check for here is (a) we're in 3-key mode (192 bits), and // (b) either K1 == K2 or K2 == K3 if (!IsLegalKeySize(rgbKey)) { throw new CryptographicException(Environment.GetResourceString("Cryptography_InvalidKeySize")); } byte[] rgbOddParityKey = Utils.FixupKeyParity(rgbKey); if (EqualBytes(rgbOddParityKey,0,8,8)) return(true); if ((rgbOddParityKey.Length == 24) && EqualBytes(rgbOddParityKey,8,16,8)) return(true); return(false); } // // private methods // private static bool EqualBytes(byte[] rgbKey, int start1, int start2, int count) { if (start1 < 0) throw new ArgumentOutOfRangeException("start1", Environment.GetResourceString("ArgumentOutOfRange_NeedNonNegNum")); if (start2 < 0) throw new ArgumentOutOfRangeException("start2", Environment.GetResourceString("ArgumentOutOfRange_NeedNonNegNum")); if ((start1+count) > rgbKey.Length) throw new ArgumentException(Environment.GetResourceString("Argument_InvalidValue")); if ((start2+count) > rgbKey.Length) throw new ArgumentException(Environment.GetResourceString("Argument_InvalidValue")); for (int i = 0; i < count; i++) { if (rgbKey[start1+i] != rgbKey[start2+i]) return(false); } return(true); } private static bool IsLegalKeySize(byte[] rgbKey) { if (rgbKey != null && ((rgbKey.Length == 16) || (rgbKey.Length == 24))) return(true); return(false); } } } // 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
- AffineTransform3D.cs
- Button.cs
- ListParaClient.cs
- QilReplaceVisitor.cs
- TableCell.cs
- ObjectViewQueryResultData.cs
- SqlDataSourceParameterParser.cs
- _HTTPDateParse.cs
- IProducerConsumerCollection.cs
- HttpCacheVaryByContentEncodings.cs
- SQLCharsStorage.cs
- ProfileSettings.cs
- ConfigurationValues.cs
- ServiceModelReg.cs
- ElementNotEnabledException.cs
- Partitioner.cs
- GrammarBuilderRuleRef.cs
- HttpCacheParams.cs
- ProviderIncompatibleException.cs
- HttpValueCollection.cs
- TargetParameterCountException.cs
- CodeAttachEventStatement.cs
- CodeLinePragma.cs
- CachedFontFace.cs
- RawStylusActions.cs
- RightsManagementProvider.cs
- UIElementHelper.cs
- LinkLabel.cs
- DoubleLink.cs
- NamedObject.cs
- Vector3DAnimationUsingKeyFrames.cs
- WebPartChrome.cs
- TimeSpanMinutesOrInfiniteConverter.cs
- SettingsPropertyValue.cs
- SelectionListDesigner.cs
- ProtocolsConfigurationEntry.cs
- PropertyItem.cs
- ProcessInfo.cs
- ImageInfo.cs
- DivideByZeroException.cs
- DecimalConstantAttribute.cs
- MissingManifestResourceException.cs
- Thumb.cs
- ObjectStateEntryDbDataRecord.cs
- RuleProcessor.cs
- Graphics.cs
- CrossAppDomainChannel.cs
- FocusWithinProperty.cs
- BaseTemplateBuildProvider.cs
- CompositeFontParser.cs
- CSharpCodeProvider.cs
- GcSettings.cs
- DragStartedEventArgs.cs
- WebService.cs
- ActivityTypeDesigner.xaml.cs
- CodeTypeParameter.cs
- EmptyEnumerable.cs
- MouseActionConverter.cs
- DebugInfoGenerator.cs
- DispatchWrapper.cs
- ZipIOCentralDirectoryFileHeader.cs
- FormsAuthenticationTicket.cs
- TimeoutException.cs
- AvTrace.cs
- BasicViewGenerator.cs
- WindowsNonControl.cs
- RuntimeArgumentHandle.cs
- MenuItemBindingCollection.cs
- TextElementEnumerator.cs
- BlurEffect.cs
- ToolStripLocationCancelEventArgs.cs
- AsymmetricKeyExchangeDeformatter.cs
- Util.cs
- _Win32.cs
- TypeSystemHelpers.cs
- KeyTimeConverter.cs
- RealProxy.cs
- FormViewModeEventArgs.cs
- GridViewAutomationPeer.cs
- RuleProcessor.cs
- BypassElement.cs
- FormViewInsertEventArgs.cs
- Parser.cs
- FillRuleValidation.cs
- CodeDefaultValueExpression.cs
- LayoutExceptionEventArgs.cs
- StringValidator.cs
- RelationshipDetailsRow.cs
- ClientConfigPaths.cs
- BehaviorEditorPart.cs
- GifBitmapEncoder.cs
- TextDecoration.cs
- SqlDataSourceWizardForm.cs
- InitializationEventAttribute.cs
- MetricEntry.cs
- MetadataFile.cs
- SafeBitVector32.cs
- ResourcePermissionBase.cs
- WebControl.cs
- TraceContext.cs