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
- HitTestDrawingContextWalker.cs
- OuterGlowBitmapEffect.cs
- GenericTypeParameterConverter.cs
- KeyToListMap.cs
- MergePropertyDescriptor.cs
- BinaryFormatterWriter.cs
- RuleConditionDialog.Designer.cs
- HttpValueCollection.cs
- OutputCacheEntry.cs
- UInt32.cs
- XamlPoint3DCollectionSerializer.cs
- HistoryEventArgs.cs
- PageAsyncTask.cs
- ObjectTokenCategory.cs
- HttpFileCollection.cs
- ListViewTableCell.cs
- BindingExpression.cs
- DriveInfo.cs
- LinearGradientBrush.cs
- StylusButton.cs
- SamlAuthenticationClaimResource.cs
- HttpResponseHeader.cs
- JsonWriterDelegator.cs
- _FixedSizeReader.cs
- NameValueConfigurationElement.cs
- TableRow.cs
- PenThread.cs
- XmlSchemaAppInfo.cs
- ErrorFormatter.cs
- XPathPatternBuilder.cs
- ObjectMaterializedEventArgs.cs
- OleDbPropertySetGuid.cs
- RemoteHelper.cs
- TextBox.cs
- FixedSOMFixedBlock.cs
- RtfFormatStack.cs
- MimeWriter.cs
- ComboBoxDesigner.cs
- IconHelper.cs
- DebugView.cs
- WebConfigurationFileMap.cs
- NavigationEventArgs.cs
- ServerIdentity.cs
- ReadOnlyObservableCollection.cs
- SystemTcpStatistics.cs
- TraceHwndHost.cs
- ConfigurationSchemaErrors.cs
- ServiceParser.cs
- ActionMessageFilterTable.cs
- _OSSOCK.cs
- GestureRecognitionResult.cs
- StaticSiteMapProvider.cs
- _SpnDictionary.cs
- ObjectDataSourceDisposingEventArgs.cs
- storepermission.cs
- TreeViewDataItemAutomationPeer.cs
- PassportIdentity.cs
- ListDictionary.cs
- StylusSystemGestureEventArgs.cs
- MeasureItemEvent.cs
- ListSortDescription.cs
- FixedSOMContainer.cs
- ComProxy.cs
- FreezableDefaultValueFactory.cs
- Delegate.cs
- Positioning.cs
- EdmRelationshipRoleAttribute.cs
- TextElementCollection.cs
- ValidatorUtils.cs
- Dispatcher.cs
- FontFamily.cs
- TerminatorSinks.cs
- HitTestResult.cs
- MemberRestriction.cs
- CustomCategoryAttribute.cs
- ScrollBarAutomationPeer.cs
- DataGridViewCellValidatingEventArgs.cs
- HtmlElement.cs
- SocketStream.cs
- ShortcutKeysEditor.cs
- DiscoveryReferences.cs
- WebResponse.cs
- DataSourceHelper.cs
- mactripleDES.cs
- SmiConnection.cs
- WmlListAdapter.cs
- ConnectionPoolManager.cs
- InstanceDataCollection.cs
- ReservationNotFoundException.cs
- InputLanguage.cs
- LinkLabel.cs
- SamlSecurityTokenAuthenticator.cs
- CssStyleCollection.cs
- SerializationSectionGroup.cs
- SqlProfileProvider.cs
- SharedPerformanceCounter.cs
- TextParagraphProperties.cs
- CollectionMarkupSerializer.cs
- XmlComplianceUtil.cs
- MiniParameterInfo.cs