Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / clr / src / BCL / System / Security / Cryptography / RSAPKCS1SignatureFormatter.cs / 1 / RSAPKCS1SignatureFormatter.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== // // RSAPKCS1SignatureFormatter.cs // namespace System.Security.Cryptography { [System.Runtime.InteropServices.ComVisible(true)] public class RSAPKCS1SignatureFormatter : AsymmetricSignatureFormatter { private RSA _rsaKey; private String _strOID; // // public constructors // public RSAPKCS1SignatureFormatter() {} public RSAPKCS1SignatureFormatter(AsymmetricAlgorithm key) { if (key == null) throw new ArgumentNullException("key"); _rsaKey = (RSA) key; } // // public methods // public override void SetKey(AsymmetricAlgorithm key) { if (key == null) throw new ArgumentNullException("key"); _rsaKey = (RSA) key; } public override void SetHashAlgorithm(String strName) { _strOID = CryptoConfig.MapNameToOID(strName); } public override byte[] CreateSignature(byte[] rgbHash) { if (_strOID == null) throw new CryptographicUnexpectedOperationException(Environment.GetResourceString("Cryptography_MissingOID")); if (_rsaKey == null) throw new CryptographicUnexpectedOperationException(Environment.GetResourceString("Cryptography_MissingKey")); if (rgbHash == null) throw new ArgumentNullException("rgbHash"); // Two cases here -- if we are talking to the CSP version or if we are talking to some other RSA provider. if (_rsaKey is RSACryptoServiceProvider) { return ((RSACryptoServiceProvider) _rsaKey).SignHash(rgbHash, _strOID); } else { byte[] pad = Utils.RsaPkcs1Padding(_rsaKey, CryptoConfig.EncodeOID(_strOID), rgbHash); // Create the signature by applying the private key to the padded buffer we just created. return _rsaKey.DecryptValue(pad); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== // // RSAPKCS1SignatureFormatter.cs // namespace System.Security.Cryptography { [System.Runtime.InteropServices.ComVisible(true)] public class RSAPKCS1SignatureFormatter : AsymmetricSignatureFormatter { private RSA _rsaKey; private String _strOID; // // public constructors // public RSAPKCS1SignatureFormatter() {} public RSAPKCS1SignatureFormatter(AsymmetricAlgorithm key) { if (key == null) throw new ArgumentNullException("key"); _rsaKey = (RSA) key; } // // public methods // public override void SetKey(AsymmetricAlgorithm key) { if (key == null) throw new ArgumentNullException("key"); _rsaKey = (RSA) key; } public override void SetHashAlgorithm(String strName) { _strOID = CryptoConfig.MapNameToOID(strName); } public override byte[] CreateSignature(byte[] rgbHash) { if (_strOID == null) throw new CryptographicUnexpectedOperationException(Environment.GetResourceString("Cryptography_MissingOID")); if (_rsaKey == null) throw new CryptographicUnexpectedOperationException(Environment.GetResourceString("Cryptography_MissingKey")); if (rgbHash == null) throw new ArgumentNullException("rgbHash"); // Two cases here -- if we are talking to the CSP version or if we are talking to some other RSA provider. if (_rsaKey is RSACryptoServiceProvider) { return ((RSACryptoServiceProvider) _rsaKey).SignHash(rgbHash, _strOID); } else { byte[] pad = Utils.RsaPkcs1Padding(_rsaKey, CryptoConfig.EncodeOID(_strOID), rgbHash); // Create the signature by applying the private key to the padded buffer we just created. return _rsaKey.DecryptValue(pad); } } } } // 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
- ExpressionConverter.cs
- ObjectTypeMapping.cs
- CheckBoxStandardAdapter.cs
- TableRow.cs
- AxHost.cs
- HTMLTextWriter.cs
- Frame.cs
- CreateUserWizardAutoFormat.cs
- ServiceXNameTypeConverter.cs
- ServerIdentity.cs
- DataGridViewTextBoxColumn.cs
- DropTarget.cs
- InvalidPipelineStoreException.cs
- ReflectionHelper.cs
- Win32SafeHandles.cs
- LicFileLicenseProvider.cs
- IPAddressCollection.cs
- RoutedEventArgs.cs
- DigestComparer.cs
- AsmxEndpointPickerExtension.cs
- CorePropertiesFilter.cs
- panel.cs
- SerialErrors.cs
- MethodCallConverter.cs
- ActivityMetadata.cs
- TrustLevel.cs
- TickBar.cs
- XmlDataDocument.cs
- ServiceChannelManager.cs
- SHA512Managed.cs
- SBCSCodePageEncoding.cs
- contentDescriptor.cs
- RangeContentEnumerator.cs
- MobileRedirect.cs
- SqlDataSourceCustomCommandPanel.cs
- DiagnosticsConfigurationHandler.cs
- FrameworkContentElement.cs
- SqlDataAdapter.cs
- MemoryMappedFile.cs
- WebBrowserBase.cs
- InvokeWebServiceDesigner.cs
- PenCursorManager.cs
- PixelFormatConverter.cs
- DoubleConverter.cs
- ScrollBar.cs
- Tokenizer.cs
- DelegatingTypeDescriptionProvider.cs
- FileDetails.cs
- IisTraceWebEventProvider.cs
- COM2PropertyBuilderUITypeEditor.cs
- RunInstallerAttribute.cs
- HttpCapabilitiesBase.cs
- ErrorCodes.cs
- Graphics.cs
- CalendarAutoFormatDialog.cs
- AutomationElementIdentifiers.cs
- Panel.cs
- ChangePasswordAutoFormat.cs
- HtmlControl.cs
- SoapSchemaMember.cs
- TextWriter.cs
- SqlInternalConnectionTds.cs
- SrgsOneOf.cs
- RouteValueDictionary.cs
- SrgsRuleRef.cs
- XmlSchemaInfo.cs
- RepeatBehaviorConverter.cs
- ListViewSelectEventArgs.cs
- StaticExtension.cs
- milexports.cs
- SafeBitVector32.cs
- CapabilitiesSection.cs
- SqlReferenceCollection.cs
- CompositeKey.cs
- ConsoleCancelEventArgs.cs
- UnSafeCharBuffer.cs
- AutoResizedEvent.cs
- CertificateReferenceElement.cs
- ApplicationContext.cs
- NestPullup.cs
- SimpleExpression.cs
- XmlUTF8TextReader.cs
- CompilerError.cs
- QuestionEventArgs.cs
- SectionVisual.cs
- SqlDataSourceCache.cs
- SynthesizerStateChangedEventArgs.cs
- Parser.cs
- FixedBufferAttribute.cs
- WebReferencesBuildProvider.cs
- Resources.Designer.cs
- XmlUtil.cs
- AvTraceDetails.cs
- Rectangle.cs
- CultureInfo.cs
- Sql8ConformanceChecker.cs
- IndexedEnumerable.cs
- activationcontext.cs
- SystemWebExtensionsSectionGroup.cs
- AuthenticatedStream.cs