Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / clr / src / BCL / System / Security / Cryptography / RijndaelManaged.cs / 1305376 / RijndaelManaged.cs
using System.Diagnostics.Contracts; // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== //[....] // // // RijndaelManaged.cs // namespace System.Security.Cryptography { [System.Runtime.InteropServices.ComVisible(true)] public sealed class RijndaelManaged : Rijndael { public RijndaelManaged () { #if FEATURE_CRYPTO if (CryptoConfig.AllowOnlyFipsAlgorithms) throw new InvalidOperationException(Environment.GetResourceString("Cryptography_NonCompliantFIPSAlgorithm")); Contract.EndContractBlock(); #endif // FEATURE_CRYPTO } // #CoreCLRRijndaelModes // // On CoreCLR we limit the supported cipher modes and padding modes for the AES algorithm to a // single hard coded value. This allows us to remove a lot of code by removing support for the // uncommon cases and forcing everyone to use the same common padding and ciper modes: // // - CipherMode: CipherMode.CBC // - PaddingMode: PaddingMode.PKCS7 public override ICryptoTransform CreateEncryptor (byte[] rgbKey, byte[] rgbIV) { return NewEncryptor(rgbKey, ModeValue, rgbIV, FeedbackSizeValue, RijndaelManagedTransformMode.Encrypt); } public override ICryptoTransform CreateDecryptor (byte[] rgbKey, byte[] rgbIV) { return NewEncryptor(rgbKey, ModeValue, rgbIV, FeedbackSizeValue, RijndaelManagedTransformMode.Decrypt); } public override void GenerateKey () { KeyValue = Utils.GenerateRandom(KeySizeValue / 8); } public override void GenerateIV () { IVValue = Utils.GenerateRandom(BlockSizeValue / 8); } private ICryptoTransform NewEncryptor (byte[] rgbKey, CipherMode mode, byte[] rgbIV, int feedbackSize, RijndaelManagedTransformMode encryptMode) { // Build the key if one does not already exist if (rgbKey == null) { rgbKey = Utils.GenerateRandom(KeySizeValue / 8); } // If not ECB mode, make sure we have an IV. In CoreCLR we do not support ECB, so we must have // an IV in all cases. #if !FEATURE_CRYPTO if (mode != CipherMode.ECB) { #endif // !FEATURE_CRYPTO if (rgbIV == null) { rgbIV = Utils.GenerateRandom(BlockSizeValue / 8); } #if !FEATURE_CRYPTO } #endif // !FEATURE_CRYPTO // Create the encryptor/decryptor object return new RijndaelManagedTransform (rgbKey, mode, rgbIV, BlockSizeValue, feedbackSize, PaddingValue, encryptMode); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. using System.Diagnostics.Contracts; // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== //[....] // // // RijndaelManaged.cs // namespace System.Security.Cryptography { [System.Runtime.InteropServices.ComVisible(true)] public sealed class RijndaelManaged : Rijndael { public RijndaelManaged () { #if FEATURE_CRYPTO if (CryptoConfig.AllowOnlyFipsAlgorithms) throw new InvalidOperationException(Environment.GetResourceString("Cryptography_NonCompliantFIPSAlgorithm")); Contract.EndContractBlock(); #endif // FEATURE_CRYPTO } // #CoreCLRRijndaelModes // // On CoreCLR we limit the supported cipher modes and padding modes for the AES algorithm to a // single hard coded value. This allows us to remove a lot of code by removing support for the // uncommon cases and forcing everyone to use the same common padding and ciper modes: // // - CipherMode: CipherMode.CBC // - PaddingMode: PaddingMode.PKCS7 public override ICryptoTransform CreateEncryptor (byte[] rgbKey, byte[] rgbIV) { return NewEncryptor(rgbKey, ModeValue, rgbIV, FeedbackSizeValue, RijndaelManagedTransformMode.Encrypt); } public override ICryptoTransform CreateDecryptor (byte[] rgbKey, byte[] rgbIV) { return NewEncryptor(rgbKey, ModeValue, rgbIV, FeedbackSizeValue, RijndaelManagedTransformMode.Decrypt); } public override void GenerateKey () { KeyValue = Utils.GenerateRandom(KeySizeValue / 8); } public override void GenerateIV () { IVValue = Utils.GenerateRandom(BlockSizeValue / 8); } private ICryptoTransform NewEncryptor (byte[] rgbKey, CipherMode mode, byte[] rgbIV, int feedbackSize, RijndaelManagedTransformMode encryptMode) { // Build the key if one does not already exist if (rgbKey == null) { rgbKey = Utils.GenerateRandom(KeySizeValue / 8); } // If not ECB mode, make sure we have an IV. In CoreCLR we do not support ECB, so we must have // an IV in all cases. #if !FEATURE_CRYPTO if (mode != CipherMode.ECB) { #endif // !FEATURE_CRYPTO if (rgbIV == null) { rgbIV = Utils.GenerateRandom(BlockSizeValue / 8); } #if !FEATURE_CRYPTO } #endif // !FEATURE_CRYPTO // Create the encryptor/decryptor object return new RijndaelManagedTransform (rgbKey, mode, rgbIV, BlockSizeValue, feedbackSize, PaddingValue, encryptMode); } } } // 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
- StrokeCollectionDefaultValueFactory.cs
- SchemaImporterExtension.cs
- ManualResetEvent.cs
- SHA256Managed.cs
- ToolStripItemEventArgs.cs
- EditorPartCollection.cs
- XamlDesignerSerializationManager.cs
- FixedStringLookup.cs
- WeakEventManager.cs
- mediaclock.cs
- TypedElement.cs
- DrawingDrawingContext.cs
- SmtpFailedRecipientsException.cs
- PersistenceContext.cs
- ServiceHostingEnvironment.cs
- Transform3D.cs
- DBCommand.cs
- ClientSection.cs
- VisualStyleInformation.cs
- QueryConverter.cs
- ScalarOps.cs
- SkinBuilder.cs
- TemplateColumn.cs
- DataControlImageButton.cs
- xdrvalidator.cs
- DiagnosticsConfiguration.cs
- SmtpReplyReaderFactory.cs
- OutputCacheSettingsSection.cs
- SmiEventSink.cs
- ProviderConnectionPoint.cs
- FutureFactory.cs
- RoleGroupCollection.cs
- XmlObjectSerializerWriteContextComplexJson.cs
- DictionaryChange.cs
- PauseStoryboard.cs
- Nullable.cs
- ListViewItem.cs
- CodeSubDirectory.cs
- LayoutUtils.cs
- InternalConfigRoot.cs
- ExplicitDiscriminatorMap.cs
- TextRangeSerialization.cs
- PointAnimationBase.cs
- DataGridViewDataErrorEventArgs.cs
- _ListenerRequestStream.cs
- Walker.cs
- Matrix3DConverter.cs
- DefaultValueAttribute.cs
- SoundPlayerAction.cs
- HMACSHA384.cs
- UITypeEditor.cs
- CodePrimitiveExpression.cs
- InvocationExpression.cs
- CompilerScopeManager.cs
- ComplexTypeEmitter.cs
- TouchDevice.cs
- ExpressionPrefixAttribute.cs
- LabelDesigner.cs
- EntityClassGenerator.cs
- TextBounds.cs
- DataGridViewComboBoxColumn.cs
- DataServiceQueryOfT.cs
- FormsAuthenticationTicket.cs
- AsnEncodedData.cs
- DrawItemEvent.cs
- ContainerSelectorBehavior.cs
- Color.cs
- Polygon.cs
- EntityDataSourceConfigureObjectContext.cs
- BaseParaClient.cs
- ResourceReferenceKeyNotFoundException.cs
- StoragePropertyMapping.cs
- BookmarkUndoUnit.cs
- MarkupProperty.cs
- OptimalBreakSession.cs
- StandardMenuStripVerb.cs
- FileEnumerator.cs
- DataServiceStreamResponse.cs
- XmlParserContext.cs
- StyleBamlRecordReader.cs
- PingReply.cs
- MsmqReceiveHelper.cs
- SupportsEventValidationAttribute.cs
- MsmqOutputMessage.cs
- DashStyles.cs
- HttpHandlersSection.cs
- ConfigurationLocation.cs
- HttpCacheParams.cs
- InstalledFontCollection.cs
- DateTimeOffset.cs
- CompilationSection.cs
- ScriptManager.cs
- CodeIdentifier.cs
- IfAction.cs
- RemoteWebConfigurationHostStream.cs
- TogglePatternIdentifiers.cs
- HttpHandlerAction.cs
- MethodSet.cs
- ItemCheckedEvent.cs
- RSATokenProvider.cs