RSAPKCS1SignatureDeformatter Třída

Definice

Ověří RSA podpis PKCS č. 1 verze 1.5.

public ref class RSAPKCS1SignatureDeformatter : System::Security::Cryptography::AsymmetricSignatureDeformatter
[System.Runtime.Versioning.UnsupportedOSPlatform("browser")]
public class RSAPKCS1SignatureDeformatter : System.Security.Cryptography.AsymmetricSignatureDeformatter
public class RSAPKCS1SignatureDeformatter : System.Security.Cryptography.AsymmetricSignatureDeformatter
[System.Runtime.InteropServices.ComVisible(true)]
public class RSAPKCS1SignatureDeformatter : System.Security.Cryptography.AsymmetricSignatureDeformatter
[<System.Runtime.Versioning.UnsupportedOSPlatform("browser")>]
type RSAPKCS1SignatureDeformatter = class
    inherit AsymmetricSignatureDeformatter
type RSAPKCS1SignatureDeformatter = class
    inherit AsymmetricSignatureDeformatter
[<System.Runtime.InteropServices.ComVisible(true)>]
type RSAPKCS1SignatureDeformatter = class
    inherit AsymmetricSignatureDeformatter
Public Class RSAPKCS1SignatureDeformatter
Inherits AsymmetricSignatureDeformatter
Dědičnost
RSAPKCS1SignatureDeformatter
Atributy

Příklady

Následující příklad ukazuje, jak použít metodu VerifySignature k ověření podpisu.

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);
                //Create an RSAPKCS1SignatureDeformatter object and pass it the  
                //RSA instance to transfer the key information.
                RSAPKCS1SignatureDeformatter RSADeformatter = new RSAPKCS1SignatureDeformatter(rsa);
                RSADeformatter.SetHashAlgorithm("SHA256");
                //Verify the hash and display the results to the console. 
                if (RSADeformatter.VerifySignature(hash, signedHash))
                {
                    Console.WriteLine("The signature was verified.");
                }
                else
                {
                    Console.WriteLine("The signature was not verified.");
                }
            }
        }
        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 instance 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)
                'Create an RSAPKCS1SignatureDeformatter object and pass it the  
                'RSA instance to transfer the key information.
                Dim RSADeformatter As New RSAPKCS1SignatureDeformatter(rsa)
                RSADeformatter.SetHashAlgorithm("SHA256")
                'Verify the hash and display the results to the console. 
                If RSADeformatter.VerifySignature(hash, signedHash) Then
                    Console.WriteLine("The signature was verified.")
                Else
                    Console.WriteLine("The signature was not verified.")
                End If
            End Using

        Catch e As CryptographicException
            Console.WriteLine(e.Message)
        End Try
    End Sub

End Class

Poznámky

Tato třída slouží k ověření digitálního podpisu vytvořeného RSA pomocí algoritmu.

Slouží RSAPKCS1SignatureFormatter k vytváření digitálních podpisů pomocí RSA algoritmu.

Konstruktory

RSAPKCS1SignatureDeformatter()

Inicializuje novou instanci RSAPKCS1SignatureDeformatter třídy.

RSAPKCS1SignatureDeformatter(AsymmetricAlgorithm)

Inicializuje novou instanci RSAPKCS1SignatureDeformatter třídy se zadaným klíčem.

Metody

Equals(Object)

Určí, zda se zadaný objekt rovná aktuálnímu objektu.

(Zděděno od Object)
GetHashCode()

Slouží jako výchozí funkce hash.

(Zděděno od Object)
GetType()

Type Získá aktuální instanci.

(Zděděno od Object)
MemberwiseClone()

Vytvoří použádnou kopii aktuálního souboru Object.

(Zděděno od Object)
SetHashAlgorithm(String)

Nastaví algoritmus hash, který se použije k ověření podpisu.

SetKey(AsymmetricAlgorithm)

Nastaví veřejný klíč, který se použije k ověření podpisu.

ToString()

Vrátí řetězec, který představuje aktuální objekt.

(Zděděno od Object)
VerifySignature(Byte[], Byte[])

Ověří RSA podpis PKCS#1 pro zadaná data.

VerifySignature(HashAlgorithm, Byte[])

Ověří podpis ze zadané hodnoty hash.

(Zděděno od AsymmetricSignatureDeformatter)

Platí pro

Viz také