次の方法で共有


RSAPKCS1SignatureFormatter.CreateSignature メソッド (Byte[])

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

Overrides Overloads Public Function CreateSignature( _
   ByVal rgbHash() As Byte _) As Byte()
[C#]
public override byte[] CreateSignature(byte[] rgbHash);
[C++]
public: unsigned char CreateSignature(unsigned charrgbHash __gc[])  __gc[];
[JScript]
public override function CreateSignature(
   rgbHash : Byte[]) : Byte[];

パラメータ

  • rgbHash
    署名するデータ。

戻り値

rgbHash のデジタル署名。

例外

例外の種類 条件
CryptographicUnexpectedOperationException キーが null 参照 (Visual Basic では Nothing) です。

または

ハッシュ アルゴリズムが null 参照 (Nothing) です。

ArgumentNullException rgbHash パラメータが null 参照 (Visual Basic では Nothing) です。

解説

このメソッドを呼び出す前に、キーとハッシュ アルゴリズムを指定する必要があります。

使用例

 
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)


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


        }
        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);
    } catch (CryptographicException* e) {
        Console::WriteLine(e->Message);
    }
}

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

必要条件

プラットフォーム: Windows 98, Windows NT 4.0, Windows Millennium Edition, Windows 2000, Windows XP Home Edition, Windows XP Professional, Windows Server 2003 ファミリ

参照

RSAPKCS1SignatureFormatter クラス | RSAPKCS1SignatureFormatter メンバ | System.Security.Cryptography 名前空間 | RSAPKCS1SignatureFormatter.CreateSignature オーバーロードの一覧 | 暗号サービス