次の方法で共有


RSAPKCS1SignatureDeformatter.VerifySignature メソッド

署名を検証します。

オーバーロードの一覧

指定したデータの RSA PKCS#1 署名を検証します。

[Visual Basic] Overloads Overrides Public Function VerifySignature(Byte(), Byte()) As Boolean

[C#] public override bool VerifySignature(byte[], byte[]);

[C++] public: bool VerifySignature(unsigned char __gc[], unsigned char __gc[]);

[JScript] public override function VerifySignature(Byte[], Byte[]) : Boolean;

AsymmetricSignatureDeformatter から継承されます。

[Visual Basic] Overloads Public Overridable Function VerifySignature(HashAlgorithm, Byte()) As Boolean

[C#] public virtual bool VerifySignature(HashAlgorithm, byte[]);

[C++] public: virtual bool VerifySignature(HashAlgorithm*, unsigned char __gc[]);

[JScript] public function VerifySignature(HashAlgorithm, Byte[]) : Boolean;

使用例

[Visual Basic, C#, C++] メモ   ここでは、VerifySignature のオーバーロード形式のうちの 1 つだけについて、使用例を示します。その他の例については、各オーバーロード形式のトピックを参照してください。

 
Imports System
Imports System.Security.Cryptography

 _

Class RSASample


    Shared Sub Main()
        Try
            'Create a new instance of RSACryptoServiceProvider.
            Dim RSA As New RSACryptoServiceProvider()

            'The hash to sign.
            Dim Hash As Byte() = {59, 4, 248, 102, 77, 97, 142, 201, 210, 12, 224, 93, 25, 41, 100, 197, 213, 134, 130, 135}

            'Create an RSAOPKCS1SignatureFormatter object and pass it the 
            'RSACryptoServiceProvider to transfer the key information.
            Dim RSAFormatter As New RSAPKCS1SignatureFormatter(RSA)

            'Set the hash algorithm to SHA1.
            RSAFormatter.SetHashAlgorithm("SHA1")

            'Create a signature for HashValue and return it.
            Dim SignedHash As Byte() = RSAFormatter.CreateSignature(Hash)

            'Create an RSAPKCS1SignatureDeformatter object and pass it the 
            'RSACryptoServiceProvider to transfer the key information.
            Dim RSADeformatter As New RSAPKCS1SignatureDeformatter(RSA)

            RSADeformatter.SetHashAlgorithm("SHA1")

            '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

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

[C#] 
using System;
using System.Security.Cryptography;

class RSASample
{
        
    static void Main()
    {
        try
        {
            //Create a new instance of RSACryptoServiceProvider.
            RSACryptoServiceProvider RSA = new RSACryptoServiceProvider();

            //The hash to sign.
            byte[] Hash = {59,4,248,102,77,97,142,201,210,12,224,93,25,41,100,197,213,134,130,135};

            //Create an RSAOPKCS1SignatureFormatter object and pass it the 
            //RSACryptoServiceProvider to transfer the key information.
            RSAPKCS1SignatureFormatter RSAFormatter = new RSAPKCS1SignatureFormatter(RSA);

            //Set the hash algorithm to SHA1.
            RSAFormatter.SetHashAlgorithm("SHA1");

            //Create a signature for HashValue and return it.
            byte[] SignedHash = RSAFormatter.CreateSignature(Hash);

            //Create an RSAPKCS1SignatureDeformatter object and pass it the 
            //RSACryptoServiceProvider to transfer the key information.
            RSAPKCS1SignatureDeformatter RSADeformatter = new RSAPKCS1SignatureDeformatter(RSA);

            RSADeformatter.SetHashAlgorithm("SHA1");

            //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);
        }
    }

}

[C++] 
#using <mscorlib.dll>
#using <System.dll>

using namespace System;
using namespace System::Security::Cryptography;

int main() {
    try {
        //Create a new instance of RSACryptoServiceProvider.
        RSACryptoServiceProvider* RSA = new RSACryptoServiceProvider();

        //The hash to sign.
        Byte Hash[] = {59,4,248,102,77,97,142,201,210,12,224,93,25,41,100,197,213,134,130,135};

        //Create an RSAOPKCS1SignatureFormatter object and pass it the 
        //RSACryptoServiceProvider to transfer the key information.
        RSAPKCS1SignatureFormatter* RSAFormatter = new RSAPKCS1SignatureFormatter(RSA);

        //Set the hash algorithm to SHA1.
        RSAFormatter->SetHashAlgorithm(S"SHA1");

        //Create a signature for HashValue and return it.
        Byte SignedHash[] = RSAFormatter->CreateSignature(Hash);

        //Create an RSAPKCS1SignatureDeformatter object and pass it the 
        //RSACryptoServiceProvider to transfer the key information.
        RSAPKCS1SignatureDeformatter* RSADeformatter = new RSAPKCS1SignatureDeformatter(RSA);

        RSADeformatter->SetHashAlgorithm(S"SHA1");

        //Verify the hash and display the results to the console.
        if (RSADeformatter->VerifySignature(Hash, SignedHash)) {
            Console::WriteLine(S"The signature was verified.");
        } else {
            Console::WriteLine(S"The signature was not verified.");
        }
    } catch (CryptographicException* e) {
        Console::WriteLine(e->Message);
    }
}

[JScript] JScript のサンプルはありません。Visual Basic、C#、および C++ のサンプルを表示するには、このページの左上隅にある言語のフィルタ ボタン 言語のフィルタ をクリックします。

参照

RSAPKCS1SignatureDeformatter クラス | RSAPKCS1SignatureDeformatter メンバ | System.Security.Cryptography 名前空間