Code:
/ FXUpdate3074 / FXUpdate3074 / 1.1 / untmp / whidbey / QFE / ndp / clr / src / BCL / System / Security / Cryptography / DES.cs / 1 / DES.cs
// ==++==
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
// ==--==
//
// DES.cs
//
namespace System.Security.Cryptography {
using System;
[System.Runtime.InteropServices.ComVisible(true)]
public abstract class DES : SymmetricAlgorithm
{
private static KeySizes[] s_legalBlockSizes = {
new KeySizes(64, 64, 0)
};
private static KeySizes[] s_legalKeySizes = {
new KeySizes(64, 64, 0)
};
//
// protected constructors
//
protected DES() {
KeySizeValue = 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 or semi-weak key
do {
GenerateKey();
} while (IsWeakKey(KeyValue) || IsSemiWeakKey(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 ArgumentException(Environment.GetResourceString("Cryptography_InvalidKeySize"));
}
if (IsWeakKey(value)) {
throw new CryptographicException(Environment.GetResourceString("Cryptography_InvalidKey_Weak"),"DES");
}
if (IsSemiWeakKey(value)) {
throw new CryptographicException(Environment.GetResourceString("Cryptography_InvalidKey_SemiWeak"),"DES");
}
KeyValue = (byte[]) value.Clone();
KeySizeValue = value.Length * 8;
}
}
//
// public methods
//
new static public DES Create() {
return Create("System.Security.Cryptography.DES");
}
new static public DES Create(String algName) {
return (DES) CryptoConfig.CreateFromName(algName);
}
public static bool IsWeakKey(byte[] rgbKey) {
if (!IsLegalKeySize(rgbKey)) {
throw new CryptographicException(Environment.GetResourceString("Cryptography_InvalidKeySize"));
}
byte[] rgbOddParityKey = Utils.FixupKeyParity(rgbKey);
UInt64 key = QuadWordFromBigEndian(rgbOddParityKey);
if ((key == 0x0101010101010101) ||
(key == 0xfefefefefefefefe) ||
(key == 0x1f1f1f1f0e0e0e0e) ||
(key == 0xe0e0e0e0f1f1f1f1)) {
return(true);
}
return(false);
}
public static bool IsSemiWeakKey(byte[] rgbKey) {
if (!IsLegalKeySize(rgbKey)) {
throw new CryptographicException(Environment.GetResourceString("Cryptography_InvalidKeySize"));
}
byte[] rgbOddParityKey = Utils.FixupKeyParity(rgbKey);
UInt64 key = QuadWordFromBigEndian(rgbOddParityKey);
if ((key == 0x01fe01fe01fe01fe) ||
(key == 0xfe01fe01fe01fe01) ||
(key == 0x1fe01fe00ef10ef1) ||
(key == 0xe01fe01ff10ef10e) ||
(key == 0x01e001e001f101f1) ||
(key == 0xe001e001f101f101) ||
(key == 0x1ffe1ffe0efe0efe) ||
(key == 0xfe1ffe1ffe0efe0e) ||
(key == 0x011f011f010e010e) ||
(key == 0x1f011f010e010e01) ||
(key == 0xe0fee0fef1fef1fe) ||
(key == 0xfee0fee0fef1fef1)) {
return(true);
}
return(false);
}
//
// private methods
//
private static bool IsLegalKeySize(byte[] rgbKey) {
if (rgbKey != null && rgbKey.Length == 8) return(true);
return(false);
}
private static UInt64 QuadWordFromBigEndian(byte[] block)
{
UInt64 x;
x = (
(((UInt64)block[0]) << 56) | (((UInt64)block[1]) << 48) |
(((UInt64)block[2]) << 40) | (((UInt64)block[3]) << 32) |
(((UInt64)block[4]) << 24) | (((UInt64)block[5]) << 16) |
(((UInt64)block[6]) << 8) | ((UInt64)block[7])
);
return(x);
}
}
}
// 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
- HtmlTableRowCollection.cs
- RegexCompiler.cs
- DbException.cs
- CommonDialog.cs
- ExpressionEditorAttribute.cs
- BamlLocalizableResource.cs
- ToolStripDropDownDesigner.cs
- FamilyCollection.cs
- TrackingStringDictionary.cs
- RawStylusActions.cs
- LinkUtilities.cs
- LinqDataSourceInsertEventArgs.cs
- XmlSchemaInfo.cs
- Point3DAnimationUsingKeyFrames.cs
- XmlSchemaSequence.cs
- ResourceExpressionEditorSheet.cs
- XamlInt32CollectionSerializer.cs
- XmlSerializationReader.cs
- DataGridTextBox.cs
- ResourcePermissionBaseEntry.cs
- Select.cs
- FlowPanelDesigner.cs
- BigInt.cs
- RemoveStoryboard.cs
- LineServices.cs
- SerialReceived.cs
- BasicExpressionVisitor.cs
- GenericNameHandler.cs
- ClickablePoint.cs
- streamingZipPartStream.cs
- LogEntry.cs
- PeerEndPoint.cs
- SystemNetworkInterface.cs
- Package.cs
- DatagridviewDisplayedBandsData.cs
- ServicePoint.cs
- EdmItemError.cs
- SettingsBase.cs
- VarRefManager.cs
- WmfPlaceableFileHeader.cs
- PointAnimationUsingPath.cs
- WebExceptionStatus.cs
- SynchronizationContext.cs
- AssemblyInfo.cs
- SecondaryIndex.cs
- Interlocked.cs
- TypeSystem.cs
- DetailsView.cs
- StyleTypedPropertyAttribute.cs
- Vector.cs
- RectangleF.cs
- ForeignConstraint.cs
- XmlSchemaSimpleContent.cs
- ConstraintCollection.cs
- TextStore.cs
- NumericPagerField.cs
- GridView.cs
- TemplateColumn.cs
- ListViewGroup.cs
- SystemUnicastIPAddressInformation.cs
- PointCollection.cs
- FileLogRecordEnumerator.cs
- XsltFunctions.cs
- ReferenceConverter.cs
- TreeViewCancelEvent.cs
- SocketElement.cs
- Light.cs
- AnnotationComponentChooser.cs
- WebServiceResponse.cs
- EFDataModelProvider.cs
- DesignSurface.cs
- KoreanCalendar.cs
- Select.cs
- TypeUnloadedException.cs
- DBCommand.cs
- TextTreeRootNode.cs
- dsa.cs
- WebPartZone.cs
- GroupBox.cs
- ThrowHelper.cs
- SessionIDManager.cs
- TextRunCacheImp.cs
- ContentTextAutomationPeer.cs
- Completion.cs
- Rotation3D.cs
- CodeDomConfigurationHandler.cs
- DataView.cs
- Int16Converter.cs
- InvalidDocumentContentsException.cs
- DataGridViewRowHeightInfoNeededEventArgs.cs
- Stylus.cs
- Parsers.cs
- GridViewCancelEditEventArgs.cs
- DockPattern.cs
- FileLogRecordStream.cs
- InteropAutomationProvider.cs
- ObjectListGeneralPage.cs
- StylusPointPropertyInfo.cs
- HttpRuntimeSection.cs
- ModelItem.cs