Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / 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
- ServerValidateEventArgs.cs
- Binding.cs
- TargetPerspective.cs
- QilGeneratorEnv.cs
- XslNumber.cs
- SqlTypesSchemaImporter.cs
- InputReferenceExpression.cs
- WorkflowViewService.cs
- BitmapDownload.cs
- PrintPageEvent.cs
- ConnectionProviderAttribute.cs
- EntityContainerRelationshipSet.cs
- DetailsViewCommandEventArgs.cs
- TitleStyle.cs
- Utils.cs
- Facet.cs
- DataGridViewLayoutData.cs
- ZipIORawDataFileBlock.cs
- TextMarkerSource.cs
- ZipFileInfo.cs
- GridViewPageEventArgs.cs
- CorrelationManager.cs
- WsiProfilesElementCollection.cs
- XmlAttributeOverrides.cs
- DataObjectEventArgs.cs
- FunctionDetailsReader.cs
- NamespaceInfo.cs
- __Error.cs
- TreeBuilder.cs
- TableItemPattern.cs
- TypeDescriptionProviderAttribute.cs
- DesignerProperties.cs
- _ConnectionGroup.cs
- ConnectionPointConverter.cs
- IPGlobalProperties.cs
- XmlCountingReader.cs
- XmlHierarchicalEnumerable.cs
- ITreeGenerator.cs
- GuidelineSet.cs
- Validator.cs
- HttpHeaderCollection.cs
- SchemaTypeEmitter.cs
- TextBounds.cs
- MessageDescription.cs
- OpCodes.cs
- DecoderBestFitFallback.cs
- EntityViewContainer.cs
- LinkedResourceCollection.cs
- WmfPlaceableFileHeader.cs
- PlanCompilerUtil.cs
- InlineUIContainer.cs
- KeyInfo.cs
- CompositeScriptReferenceEventArgs.cs
- DataGridDefaultColumnWidthTypeConverter.cs
- Underline.cs
- CrossSiteScriptingValidation.cs
- SecurityCriticalDataForSet.cs
- StylusLogic.cs
- ECDiffieHellmanCngPublicKey.cs
- UrlPath.cs
- DynamicPropertyHolder.cs
- SerializationStore.cs
- LayoutEvent.cs
- PrimitiveXmlSerializers.cs
- CryptoKeySecurity.cs
- FtpRequestCacheValidator.cs
- Timer.cs
- Image.cs
- CodeExpressionCollection.cs
- SerialReceived.cs
- FixUp.cs
- XmlILAnnotation.cs
- RenderingEventArgs.cs
- NameValueSectionHandler.cs
- ListInitExpression.cs
- CodeDirectoryCompiler.cs
- EntryWrittenEventArgs.cs
- ObjectItemLoadingSessionData.cs
- FtpWebRequest.cs
- DataColumnMappingCollection.cs
- MemberPathMap.cs
- NotCondition.cs
- activationcontext.cs
- ActionFrame.cs
- UserControlBuildProvider.cs
- XmlSchemaAnnotated.cs
- ZeroOpNode.cs
- ImageButton.cs
- TransformGroup.cs
- AutomationIdentifierGuids.cs
- SiteMap.cs
- CheckBoxBaseAdapter.cs
- ThicknessAnimation.cs
- InteropBitmapSource.cs
- GAC.cs
- OleAutBinder.cs
- WebPartTransformer.cs
- UnsafeNativeMethods.cs
- SQLString.cs
- ContextMenuStrip.cs