Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / clr / src / BCL / System / Security / Cryptography / RSAPKCS1KeyExchangeDeformatter.cs / 1 / RSAPKCS1KeyExchangeDeformatter.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== namespace System.Security.Cryptography { [System.Runtime.InteropServices.ComVisible(true)] public class RSAPKCS1KeyExchangeDeformatter : AsymmetricKeyExchangeDeformatter { RSA _rsaKey; RandomNumberGenerator RngValue; // Constructors public RSAPKCS1KeyExchangeDeformatter() {} public RSAPKCS1KeyExchangeDeformatter(AsymmetricAlgorithm key) { if (key == null) throw new ArgumentNullException("key"); _rsaKey = (RSA) key; } // // public properties // public RandomNumberGenerator RNG { get { return RngValue; } set { RngValue = value; } } public override String Parameters { get { return null; } set { ;} } // // public methods // public override byte[] DecryptKeyExchange(byte[] rgbIn) { if (_rsaKey == null) throw new CryptographicUnexpectedOperationException(Environment.GetResourceString("Cryptography_MissingKey")); byte[] rgbOut; if (_rsaKey is RSACryptoServiceProvider) { rgbOut = ((RSACryptoServiceProvider) _rsaKey).Decrypt(rgbIn, false); } else { int i; byte[] rgb; rgb = _rsaKey.DecryptValue(rgbIn); // // Expected format is: // 00 || 02 || PS || 00 || D // where PS does not contain any zeros. // for (i = 2; i= rgb.Length) throw new CryptographicUnexpectedOperationException(Environment.GetResourceString("Cryptography_PKCS1Decoding")); i++; // Skip over the zero rgbOut = new byte[rgb.Length - i]; Buffer.InternalBlockCopy(rgb, i, rgbOut, 0, rgbOut.Length); } return rgbOut; } public override void SetKey(AsymmetricAlgorithm key) { if (key == null) throw new ArgumentNullException("key"); _rsaKey = (RSA) key; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== namespace System.Security.Cryptography { [System.Runtime.InteropServices.ComVisible(true)] public class RSAPKCS1KeyExchangeDeformatter : AsymmetricKeyExchangeDeformatter { RSA _rsaKey; RandomNumberGenerator RngValue; // Constructors public RSAPKCS1KeyExchangeDeformatter() {} public RSAPKCS1KeyExchangeDeformatter(AsymmetricAlgorithm key) { if (key == null) throw new ArgumentNullException("key"); _rsaKey = (RSA) key; } // // public properties // public RandomNumberGenerator RNG { get { return RngValue; } set { RngValue = value; } } public override String Parameters { get { return null; } set { ;} } // // public methods // public override byte[] DecryptKeyExchange(byte[] rgbIn) { if (_rsaKey == null) throw new CryptographicUnexpectedOperationException(Environment.GetResourceString("Cryptography_MissingKey")); byte[] rgbOut; if (_rsaKey is RSACryptoServiceProvider) { rgbOut = ((RSACryptoServiceProvider) _rsaKey).Decrypt(rgbIn, false); } else { int i; byte[] rgb; rgb = _rsaKey.DecryptValue(rgbIn); // // Expected format is: // 00 || 02 || PS || 00 || D // where PS does not contain any zeros. // for (i = 2; i = rgb.Length) throw new CryptographicUnexpectedOperationException(Environment.GetResourceString("Cryptography_PKCS1Decoding")); i++; // Skip over the zero rgbOut = new byte[rgb.Length - i]; Buffer.InternalBlockCopy(rgb, i, rgbOut, 0, rgbOut.Length); } return rgbOut; } public override void SetKey(AsymmetricAlgorithm key) { if (key == null) throw new ArgumentNullException("key"); _rsaKey = (RSA) key; } } } // 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
- EntryWrittenEventArgs.cs
- LineServicesCallbacks.cs
- SignedXml.cs
- XmlBinaryReader.cs
- CompareInfo.cs
- LinearGradientBrush.cs
- DescendantOverDescendantQuery.cs
- OleDbConnectionPoolGroupProviderInfo.cs
- SortQueryOperator.cs
- NumericUpDown.cs
- SafeBuffer.cs
- ColumnResizeAdorner.cs
- HttpVersion.cs
- Debugger.cs
- RegexCaptureCollection.cs
- StatusBarDrawItemEvent.cs
- SafeRightsManagementPubHandle.cs
- DbgUtil.cs
- Collection.cs
- DataMisalignedException.cs
- ObjectMemberMapping.cs
- PersonalizationAdministration.cs
- SafeWaitHandle.cs
- Interlocked.cs
- BamlCollectionHolder.cs
- UriParserTemplates.cs
- RecordManager.cs
- BCryptNative.cs
- BatchParser.cs
- AncillaryOps.cs
- XmlSchemaSimpleContent.cs
- BufferAllocator.cs
- CollectionChange.cs
- WebBrowsableAttribute.cs
- WebCategoryAttribute.cs
- HttpApplicationStateBase.cs
- HexParser.cs
- SQLConvert.cs
- XpsS0ValidatingLoader.cs
- AttributeEmitter.cs
- XmlNotation.cs
- UnsafeNativeMethodsMilCoreApi.cs
- PopOutPanel.cs
- LayoutEvent.cs
- DeploymentExceptionMapper.cs
- CookieHandler.cs
- HttpProfileGroupBase.cs
- ZoneMembershipCondition.cs
- IdentifierCollection.cs
- TraceHandler.cs
- COM2IDispatchConverter.cs
- FragmentQueryKB.cs
- XmlSchemaChoice.cs
- XmlText.cs
- TerminatorSinks.cs
- FunctionImportMapping.cs
- WebAdminConfigurationHelper.cs
- SrgsElement.cs
- SSmlParser.cs
- PrintPreviewGraphics.cs
- ObjectDataSourceMethodEventArgs.cs
- ConstNode.cs
- ZipIOBlockManager.cs
- VariableAction.cs
- DataListCommandEventArgs.cs
- HtmlControlPersistable.cs
- Parameter.cs
- CompositeDataBoundControl.cs
- DocumentPageHost.cs
- DbgUtil.cs
- ContentIterators.cs
- LabelExpression.cs
- DataSourceDesigner.cs
- Authorization.cs
- WhiteSpaceTrimStringConverter.cs
- LinqDataSourceInsertEventArgs.cs
- DragSelectionMessageFilter.cs
- EnvironmentPermission.cs
- DesignerOptionService.cs
- SpotLight.cs
- DelegateBodyWriter.cs
- RuntimeEnvironment.cs
- DataTableCollection.cs
- unsafeIndexingFilterStream.cs
- RegistrySecurity.cs
- SchemaNames.cs
- IODescriptionAttribute.cs
- RuleSet.cs
- DBCommand.cs
- MenuItem.cs
- SingleObjectCollection.cs
- WaitHandleCannotBeOpenedException.cs
- WebEventCodes.cs
- RetrieveVirtualItemEventArgs.cs
- SignatureHelper.cs
- WindowsMenu.cs
- Item.cs
- RangeValidator.cs
- HealthMonitoringSection.cs
- IntegerFacetDescriptionElement.cs