本文整理匯總了C#中System.Security.Cryptography.SignatureDescription類的典型用法代碼示例。如果您正苦於以下問題:C# SignatureDescription類的具體用法?C# SignatureDescription怎麽用?C# SignatureDescription使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
SignatureDescription類屬於System.Security.Cryptography命名空間,在下文中一共展示了SignatureDescription類的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: Main
//引入命名空間
using System;
using System.Security;
using System.Security.Cryptography;
class SignatureDescriptionImpl
{
[STAThread]
static void Main(string[] args)
{
// Create a digital signature based on RSA encryption.
SignatureDescription rsaSignature = CreateRSAPKCS1Signature();
ShowProperties(rsaSignature);
// Create a digital signature based on DSA encryption.
SignatureDescription dsaSignature = CreateDSASignature();
ShowProperties(dsaSignature);
// Create a HashAlgorithm using the digest algorithm of the signature.
HashAlgorithm hashAlgorithm = dsaSignature.CreateDigest();
Console.WriteLine("\nHash algorithm for the DigestAlgorithm property:"
+ " " + hashAlgorithm.ToString());
// Create an AsymmetricSignatureFormatter instance using the DSA key.
DSA dsa = DSA.Create();
AsymmetricSignatureFormatter asymmetricFormatter =
CreateDSAFormatter(dsa);
// Create an AsymmetricSignatureDeformatter instance using the
// DSA key.
AsymmetricSignatureDeformatter asymmetricDeformatter =
CreateDSADeformatter(dsa);
Console.WriteLine("This sample completed successfully; " +
"press Enter to exit.");
Console.ReadLine();
}
// Create a SignatureDescription for RSA encryption.
private static SignatureDescription CreateRSAPKCS1Signature()
{
SignatureDescription signatureDescription =
new SignatureDescription();
// Set the key algorithm property for RSA encryption.
signatureDescription.KeyAlgorithm =
"System.Security.Cryptography.RSACryptoServiceProvider";
// Set the digest algorithm for RSA encryption using the
// SHA1 provider.
signatureDescription.DigestAlgorithm =
"System.Security.Cryptography.SHA1CryptoServiceProvider";
// Set the formatter algorithm with the RSAPKCS1 formatter.
signatureDescription.FormatterAlgorithm =
"System.Security.Cryptography.RSAPKCS1SignatureFormatter";
// Set the formatter algorithm with the RSAPKCS1 deformatter.
signatureDescription.DeformatterAlgorithm =
"System.Security.Cryptography.RSAPKCS1SignatureDeformatter";
return signatureDescription;
}
// Create a SignatureDescription using a constructed SecurityElement for
// DSA encryption.
private static SignatureDescription CreateDSASignature()
{
SecurityElement securityElement = new SecurityElement("DSASignature");
// Create new security elements for the four algorithms.
securityElement.AddChild(new SecurityElement(
"Key",
"System.Security.Cryptography.DSACryptoServiceProvider"));
securityElement.AddChild(new SecurityElement(
"Digest",
"System.Security.Cryptography.SHA1CryptoServiceProvider"));
securityElement.AddChild(new SecurityElement(
"Formatter",
"System.Security.Cryptography.DSASignatureFormatter"));
securityElement.AddChild(new SecurityElement(
"Deformatter",
"System.Security.Cryptography.DSASignatureDeformatter"));
SignatureDescription signatureDescription =
new SignatureDescription(securityElement);
return signatureDescription;
}
// Create a signature formatter for DSA encryption.
private static AsymmetricSignatureFormatter CreateDSAFormatter(DSA dsa)
{
// Create a DSA signature formatter for encryption.
SignatureDescription signatureDescription =
new SignatureDescription();
signatureDescription.FormatterAlgorithm =
"System.Security.Cryptography.DSASignatureFormatter";
AsymmetricSignatureFormatter asymmetricFormatter =
signatureDescription.CreateFormatter(dsa);
Console.WriteLine("\nCreated formatter : " +
asymmetricFormatter.ToString());
return asymmetricFormatter;
}
// Create a signature deformatter for DSA decryption.
private static AsymmetricSignatureDeformatter CreateDSADeformatter(
DSA dsa)
{
// Create a DSA signature deformatter to verify the signature.
SignatureDescription signatureDescription =
new SignatureDescription();
signatureDescription.DeformatterAlgorithm =
"System.Security.Cryptography.DSASignatureDeformatter";
AsymmetricSignatureDeformatter asymmetricDeformatter =
signatureDescription.CreateDeformatter(dsa);
Console.WriteLine("\nCreated deformatter : " +
asymmetricDeformatter.ToString());
return asymmetricDeformatter;
}
// Display to the console the properties of the specified
// SignatureDescription.
private static void ShowProperties(
SignatureDescription signatureDescription)
{
// Retrieve the class path for the specified SignatureDescription.
string classDescription = signatureDescription.ToString();
string deformatterAlgorithm =
signatureDescription.DeformatterAlgorithm;
string formatterAlgorithm = signatureDescription.FormatterAlgorithm;
string digestAlgorithm = signatureDescription.DigestAlgorithm;
string keyAlgorithm = signatureDescription.KeyAlgorithm;
Console.WriteLine("\n** " + classDescription + " **");
Console.WriteLine("DeformatterAlgorithm : " + deformatterAlgorithm);
Console.WriteLine("FormatterAlgorithm : " + formatterAlgorithm);
Console.WriteLine("DigestAlgorithm : " + digestAlgorithm);
Console.WriteLine("KeyAlgorithm : " + keyAlgorithm);
}
}
//
輸出:
** System.Security.Cryptography.SignatureDescription ** DeformatterAlgorithm : System.Security.Cryptography. RSAPKCS1SignatureDeformatter FormatterAlgorithm : System.Security.Cryptography. RSAPKCS1SignatureFormatter DigestAlgorithm : System.Security.Cryptography.SHA1CryptoServiceProvider KeyAlgorithm : System.Security.Cryptography.RSACryptoServiceProvider ** System.Security.Cryptography.SignatureDescription ** DeformatterAlgorithm : System.Security.Cryptography.DSASignatureDeformatter FormatterAlgorithm : System.Security.Cryptography.DSASignatureFormatter DigestAlgorithm : System.Security.Cryptography.SHA1CryptoServiceProvider KeyAlgorithm : System.Security.Cryptography.DSACryptoServiceProvider Hash algorithm for the DigestAlgorithm property: System.Security.Cryptography.SH A1CryptoServiceProvider Created formatter : System.Security.Cryptography.DSASignatureFormatter Created deformatter : System.Security.Cryptography.DSASignatureDeformatter This sample completed successfully; press Enter to exit.