RSAPKCS1SignatureFormatter.CreateSignature(Byte[]) 方法   
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
为指定数据创建 RSA PKCS #1 签名。
public:
 override cli::array <System::Byte> ^ CreateSignature(cli::array <System::Byte> ^ rgbHash);public override byte[] CreateSignature(byte[] rgbHash);override this.CreateSignature : byte[] -> byte[]Public Overrides Function CreateSignature (rgbHash As Byte()) As Byte()参数
- rgbHash
- Byte[]
要签名的数据。
返回
		Byte[]
		
	
	
              rgbHash 的数字签名。
例外
              rgbHash 参数为 null。
示例
以下示例演示如何创建 PKCS #1 版本 1.5 签名。
using System;
using System.Security.Cryptography;
class RSASample
{
    static void Main()
    {
        try
        {
            //Create a new instance of RSA.
            using (RSA rsa = RSA.Create())
            {
                //The hash to sign.
                byte[] hash;
                using (SHA256 sha256 = SHA256.Create())
                {
                    byte[] data = new byte[] { 59, 4, 248, 102, 77, 97, 142, 201, 210, 12, 224, 93, 25, 41, 100, 197, 213, 134, 130, 135 };
                    hash = sha256.ComputeHash(data);
                }
                //Create an RSASignatureFormatter object and pass it the 
                //RSA instance to transfer the key information.
                RSAPKCS1SignatureFormatter RSAFormatter = new RSAPKCS1SignatureFormatter(rsa);
                //Set the hash algorithm to SHA256.
                RSAFormatter.SetHashAlgorithm("SHA256");
                //Create a signature for HashValue and return it.
                byte[] SignedHash = RSAFormatter.CreateSignature(hash);
            }
        }
        catch (CryptographicException e)
        {
            Console.WriteLine(e.Message);
        }
    }
}
Imports System.Security.Cryptography
Friend Class RSASample
    Shared Sub Main()
        Try
            'Create a new instance of RSA.
            Using rsa As RSA = RSA.Create()
                'The hash to sign.
                Dim hash() As Byte
                Using sha256 As SHA256 = SHA256.Create()
                    Dim data() As Byte = { 59, 4, 248, 102, 77, 97, 142, 201, 210, 12, 224, 93, 25, 41, 100, 197, 213, 134, 130, 135 }
                    hash = sha256.ComputeHash(data)
                End Using
                'Create an RSASignatureFormatter object and pass it the 
                'RSA to transfer the key information.
                Dim RSAFormatter As New RSAPKCS1SignatureFormatter(rsa)
                'Set the hash algorithm to SHA256.
                RSAFormatter.SetHashAlgorithm("SHA256")
                'Create a signature for HashValue and return it.
                Dim SignedHash() As Byte = RSAFormatter.CreateSignature(hash)
            End Using
        Catch e As CryptographicException
            Console.WriteLine(e.Message)
        End Try
    End Sub
End Class
注解
在调用此方法之前,必须指定密钥和哈希算法。