RSACryptoServiceProvider.SignData 메서드
정의
중요
일부 정보는 릴리스되기 전에 상당 부분 수정될 수 있는 시험판 제품과 관련이 있습니다. Microsoft는 여기에 제공된 정보에 대해 어떠한 명시적이거나 묵시적인 보증도 하지 않습니다.
지정된 데이터의 해시 값을 계산하고 서명합니다.
오버로드
SignData(Byte[], Object) |
지정된 해시 알고리즘을 사용하여 지정된 바이트 배열의 해시 값을 계산하고 결과 해시 값을 서명합니다. |
SignData(Stream, Object) |
지정된 해시 알고리즘을 사용하여 지정된 입력 스트림의 해시 값을 계산하고 결과 해시 값을 서명합니다. |
SignData(Byte[], Int32, Int32, Object) |
지정된 해시 알고리즘을 사용하여 지정된 바이트 배열 하위 집합의 해시 값을 계산하고 결과 해시 값을 서명합니다. |
SignData(Byte[], Object)
지정된 해시 알고리즘을 사용하여 지정된 바이트 배열의 해시 값을 계산하고 결과 해시 값을 서명합니다.
public:
cli::array <System::Byte> ^ SignData(cli::array <System::Byte> ^ buffer, System::Object ^ halg);
public byte[] SignData (byte[] buffer, object halg);
override this.SignData : byte[] * obj -> byte[]
member this.SignData : byte[] * obj -> byte[]
Public Function SignData (buffer As Byte(), halg As Object) As Byte()
매개 변수
- buffer
- Byte[]
해시하고 서명할 입력 데이터입니다.
- halg
- Object
해시 값을 만드는 데 사용할 해시 알고리즘입니다.
반환
지정된 데이터의 RSA 서명입니다.
예외
halg
매개 변수가 null
인 경우
halg
매개 변수의 형식이 잘못된 경우
예제
다음 코드 예제에서는 데이터에 서명하고 확인합니다.
using namespace System;
using namespace System::Security::Cryptography;
using namespace System::Text;
array<Byte>^ HashAndSignBytes( array<Byte>^DataToSign, RSAParameters Key )
{
try
{
// Create a new instance of RSACryptoServiceProvider using the
// key from RSAParameters.
RSACryptoServiceProvider^ RSAalg = gcnew RSACryptoServiceProvider;
RSAalg->ImportParameters( Key );
// Hash and sign the data. Pass a new instance of SHA256
// to specify the hashing algorithm.
return RSAalg->SignData( DataToSign, SHA256::Create() );
}
catch ( CryptographicException^ e )
{
Console::WriteLine( e->Message );
return nullptr;
}
}
bool VerifySignedHash( array<Byte>^DataToVerify, array<Byte>^SignedData, RSAParameters Key )
{
try
{
// Create a new instance of RSACryptoServiceProvider using the
// key from RSAParameters.
RSACryptoServiceProvider^ RSAalg = gcnew RSACryptoServiceProvider;
RSAalg->ImportParameters( Key );
// Verify the data using the signature. Pass a new instance of SHA256
// to specify the hashing algorithm.
return RSAalg->VerifyData( DataToVerify, SHA256::Create(), SignedData );
}
catch ( CryptographicException^ e )
{
Console::WriteLine( e->Message );
return false;
}
}
int main()
{
try
{
// Create a UnicodeEncoder to convert between byte array and string.
ASCIIEncoding^ ByteConverter = gcnew ASCIIEncoding;
String^ dataString = "Data to Sign";
// Create byte arrays to hold original, encrypted, and decrypted data.
array<Byte>^originalData = ByteConverter->GetBytes( dataString );
array<Byte>^signedData;
// Create a new instance of the RSACryptoServiceProvider class
// and automatically create a new key-pair.
RSACryptoServiceProvider^ RSAalg = gcnew RSACryptoServiceProvider;
// Export the key information to an RSAParameters object.
// You must pass true to export the private key for signing.
// However, you do not need to export the private key
// for verification.
RSAParameters Key = RSAalg->ExportParameters( true );
// Hash and sign the data.
signedData = HashAndSignBytes( originalData, Key );
// Verify the data and display the result to the
// console.
if ( VerifySignedHash( originalData, signedData, Key ) )
{
Console::WriteLine( "The data was verified." );
}
else
{
Console::WriteLine( "The data does not match the signature." );
}
}
catch ( ArgumentNullException^ )
{
Console::WriteLine( "The data was not signed or verified" );
}
}
using System;
using System.Security.Cryptography;
using System.Text;
class RSACSPSample
{
static void Main()
{
try
{
// Create a UnicodeEncoder to convert between byte array and string.
ASCIIEncoding ByteConverter = new ASCIIEncoding();
string dataString = "Data to Sign";
// Create byte arrays to hold original, encrypted, and decrypted data.
byte[] originalData = ByteConverter.GetBytes(dataString);
byte[] signedData;
// Create a new instance of the RSACryptoServiceProvider class
// and automatically create a new key-pair.
RSACryptoServiceProvider RSAalg = new RSACryptoServiceProvider();
// Export the key information to an RSAParameters object.
// You must pass true to export the private key for signing.
// However, you do not need to export the private key
// for verification.
RSAParameters Key = RSAalg.ExportParameters(true);
// Hash and sign the data.
signedData = HashAndSignBytes(originalData, Key);
// Verify the data and display the result to the
// console.
if(VerifySignedHash(originalData, signedData, Key))
{
Console.WriteLine("The data was verified.");
}
else
{
Console.WriteLine("The data does not match the signature.");
}
}
catch(ArgumentNullException)
{
Console.WriteLine("The data was not signed or verified");
}
}
public static byte[] HashAndSignBytes(byte[] DataToSign, RSAParameters Key)
{
try
{
// Create a new instance of RSACryptoServiceProvider using the
// key from RSAParameters.
RSACryptoServiceProvider RSAalg = new RSACryptoServiceProvider();
RSAalg.ImportParameters(Key);
// Hash and sign the data. Pass a new instance of SHA256
// to specify the hashing algorithm.
return RSAalg.SignData(DataToSign, SHA256.Create());
}
catch(CryptographicException e)
{
Console.WriteLine(e.Message);
return null;
}
}
public static bool VerifySignedHash(byte[] DataToVerify, byte[] SignedData, RSAParameters Key)
{
try
{
// Create a new instance of RSACryptoServiceProvider using the
// key from RSAParameters.
RSACryptoServiceProvider RSAalg = new RSACryptoServiceProvider();
RSAalg.ImportParameters(Key);
// Verify the data using the signature. Pass a new instance of SHA256
// to specify the hashing algorithm.
return RSAalg.VerifyData(DataToVerify, SHA256.Create(), SignedData);
}
catch(CryptographicException e)
{
Console.WriteLine(e.Message);
return false;
}
}
}
Imports System.Security.Cryptography
Imports System.Text
Module RSACSPExample
Sub Main()
Try
' Create a UnicodeEncoder to convert between byte array and string.
Dim ByteConverter As New ASCIIEncoding
Dim dataString As String = "Data to Sign"
' Create byte arrays to hold original, encrypted, and decrypted data.
Dim originalData As Byte() = ByteConverter.GetBytes(dataString)
Dim signedData() As Byte
' Create a new instance of the RSACryptoServiceProvider class
' and automatically create a new key-pair.
Dim RSAalg As New RSACryptoServiceProvider
' Export the key information to an RSAParameters object.
' You must pass true to export the private key for signing.
' However, you do not need to export the private key
' for verification.
Dim Key As RSAParameters = RSAalg.ExportParameters(True)
' Hash and sign the data.
signedData = HashAndSignBytes(originalData, Key)
' Verify the data and display the result to the
' console.
If VerifySignedHash(originalData, signedData, Key) Then
Console.WriteLine("The data was verified.")
Else
Console.WriteLine("The data does not match the signature.")
End If
Catch e As ArgumentNullException
Console.WriteLine("The data was not signed or verified.")
End Try
End Sub
Function HashAndSignBytes(ByVal DataToSign() As Byte, ByVal Key As RSAParameters) As Byte()
Try
' Create a new instance of RSACryptoServiceProvider using the
' key from RSAParameters.
Dim RSAalg As New RSACryptoServiceProvider
RSAalg.ImportParameters(Key)
' Hash and sign the data. Pass a new instance of SHA256
' to specify the hashing algorithm.
Return RSAalg.SignData(DataToSign, SHA256.Create())
Catch e As CryptographicException
Console.WriteLine(e.Message)
Return Nothing
End Try
End Function
Function VerifySignedHash(ByVal DataToVerify() As Byte, ByVal SignedData() As Byte, ByVal Key As RSAParameters) As Boolean
Try
' Create a new instance of RSACryptoServiceProvider using the
' key from RSAParameters.
Dim RSAalg As New RSACryptoServiceProvider
RSAalg.ImportParameters(Key)
' Verify the data using the signature. Pass a new instance of SHA256
' to specify the hashing algorithm.
Return RSAalg.VerifyData(DataToVerify, SHA256.Create(), SignedData)
Catch e As CryptographicException
Console.WriteLine(e.Message)
Return False
End Try
End Function
End Module
설명
이 메서드는 메서드를 사용하여 VerifyData 확인된 디지털 서명을 만듭니다.
매개 변수는 halg
, 또는 를 HashAlgorithm수락String할 Type수 있습니다.
추가 정보
적용 대상
SignData(Stream, Object)
지정된 해시 알고리즘을 사용하여 지정된 입력 스트림의 해시 값을 계산하고 결과 해시 값을 서명합니다.
public:
cli::array <System::Byte> ^ SignData(System::IO::Stream ^ inputStream, System::Object ^ halg);
public byte[] SignData (System.IO.Stream inputStream, object halg);
override this.SignData : System.IO.Stream * obj -> byte[]
member this.SignData : System.IO.Stream * obj -> byte[]
Public Function SignData (inputStream As Stream, halg As Object) As Byte()
매개 변수
- inputStream
- Stream
해시하고 서명할 입력 스트림입니다.
- halg
- Object
해시 값을 만드는 데 사용할 해시 알고리즘입니다.
반환
지정된 데이터의 RSA 서명입니다.
예외
halg
매개 변수가 null
인 경우
halg
매개 변수의 형식이 잘못된 경우
예제
다음 코드 예제에서는 데이터에 서명하고 확인합니다.
using namespace System;
using namespace System::Security::Cryptography;
using namespace System::Text;
using namespace System::IO;
array<Byte>^ HashAndSignBytes( Stream^ DataStream, RSAParameters Key )
{
try
{
// Reset the current position in the stream to
// the beginning of the stream (0). RSACryptoServiceProvider
// can't verify the data unless the stream position
// is set to the starting position of the data.
DataStream->Position = 0;
// Create a new instance of RSACryptoServiceProvider using the
// key from RSAParameters.
RSACryptoServiceProvider^ RSAalg = gcnew RSACryptoServiceProvider;
RSAalg->ImportParameters( Key );
// Hash and sign the data. Pass a new instance of SHA256
// to specify the hashing algorithm.
return RSAalg->SignData( DataStream, SHA256::Create() );
}
catch ( CryptographicException^ e )
{
Console::WriteLine( e->Message );
return nullptr;
}
}
bool VerifySignedHash( array<Byte>^DataToVerify, array<Byte>^SignedData, RSAParameters Key )
{
try
{
// Create a new instance of RSACryptoServiceProvider using the
// key from RSAParameters.
RSACryptoServiceProvider^ RSAalg = gcnew RSACryptoServiceProvider;
RSAalg->ImportParameters( Key );
// Verify the data using the signature. Pass a new instance of SHA256
// to specify the hashing algorithm.
return RSAalg->VerifyData( DataToVerify, SHA256(), SignedData );
}
catch ( CryptographicException^ e )
{
Console::WriteLine( e->Message );
return false;
}
}
int main()
{
try
{
ASCIIEncoding^ ByteConverter = gcnew ASCIIEncoding;
// Create some bytes to be signed.
array<Byte>^dataBytes = ByteConverter->GetBytes( "Here is some data to sign!" );
// Create a buffer for the memory stream.
array<Byte>^buffer = gcnew array<Byte>(dataBytes->Length);
// Create a MemoryStream.
MemoryStream^ mStream = gcnew MemoryStream( buffer );
// Write the bytes to the stream and flush it.
mStream->Write( dataBytes, 0, dataBytes->Length );
mStream->Flush();
// Create a new instance of the RSACryptoServiceProvider class
// and automatically create a new key-pair.
RSACryptoServiceProvider^ RSAalg = gcnew RSACryptoServiceProvider;
// Export the key information to an RSAParameters object.
// You must pass true to export the private key for signing.
// However, you do not need to export the private key
// for verification.
RSAParameters Key = RSAalg->ExportParameters( true );
// Hash and sign the data.
array<Byte>^signedData = HashAndSignBytes( mStream, Key );
// Verify the data and display the result to the
// console.
if ( VerifySignedHash( dataBytes, signedData, Key ) )
{
Console::WriteLine( "The data was verified." );
}
else
{
Console::WriteLine( "The data does not match the signature." );
}
// Close the MemoryStream.
mStream->Close();
}
catch ( ArgumentNullException^ )
{
Console::WriteLine( "The data was not signed or verified" );
}
}
using System;
using System.Security.Cryptography;
using System.Text;
using System.IO;
class RSACSPSample
{
static void Main()
{
try
{
ASCIIEncoding ByteConverter = new ASCIIEncoding();
// Create some bytes to be signed.
byte[] dataBytes = ByteConverter.GetBytes("Here is some data to sign!");
// Create a buffer for the memory stream.
byte[] buffer = new byte[dataBytes.Length];
// Create a MemoryStream.
MemoryStream mStream = new MemoryStream(buffer);
// Write the bytes to the stream and flush it.
mStream.Write(dataBytes, 0, dataBytes.Length);
mStream.Flush();
// Create a new instance of the RSACryptoServiceProvider class
// and automatically create a new key-pair.
RSACryptoServiceProvider RSAalg = new RSACryptoServiceProvider();
// Export the key information to an RSAParameters object.
// You must pass true to export the private key for signing.
// However, you do not need to export the private key
// for verification.
RSAParameters Key = RSAalg.ExportParameters(true);
// Hash and sign the data.
byte[] signedData = HashAndSignBytes(mStream, Key);
// Verify the data and display the result to the
// console.
if(VerifySignedHash(dataBytes, signedData, Key))
{
Console.WriteLine("The data was verified.");
}
else
{
Console.WriteLine("The data does not match the signature.");
}
// Close the MemoryStream.
mStream.Close();
}
catch(ArgumentNullException)
{
Console.WriteLine("The data was not signed or verified");
}
}
public static byte[] HashAndSignBytes(Stream DataStream, RSAParameters Key)
{
try
{
// Reset the current position in the stream to
// the beginning of the stream (0). RSACryptoServiceProvider
// can't verify the data unless the stream position
// is set to the starting position of the data.
DataStream.Position = 0;
// Create a new instance of RSACryptoServiceProvider using the
// key from RSAParameters.
RSACryptoServiceProvider RSAalg = new RSACryptoServiceProvider();
RSAalg.ImportParameters(Key);
// Hash and sign the data. Pass a new instance of SHA256
// to specify the hashing algorithm.
return RSAalg.SignData(DataStream, SHA256.Create());
}
catch(CryptographicException e)
{
Console.WriteLine(e.Message);
return null;
}
}
public static bool VerifySignedHash(byte[] DataToVerify, byte[] SignedData, RSAParameters Key)
{
try
{
// Create a new instance of RSACryptoServiceProvider using the
// key from RSAParameters.
RSACryptoServiceProvider RSAalg = new RSACryptoServiceProvider();
RSAalg.ImportParameters(Key);
// Verify the data using the signature. Pass a new instance of SHA256
// to specify the hashing algorithm.
return RSAalg.VerifyData(DataToVerify, SHA256.Create(), SignedData);
}
catch(CryptographicException e)
{
Console.WriteLine(e.Message);
return false;
}
}
}
Imports System.Security.Cryptography
Imports System.Text
Imports System.IO
Module RSACSPExample
Sub Main()
Try
Dim ByteConverter As New ASCIIEncoding
' Create some bytes to be signed.
Dim dataBytes As Byte() = ByteConverter.GetBytes("Here is some data to sign!")
' Create a buffer for the memory stream.
' VB automatically pads arrays with an extra
' Digit of "0".
' RSACryptoServiceProvider will not verify
' the buffer if the automatic padding is
' present. To remove the padding, decrement
' the buffer length by 1.
Dim buffer(dataBytes.Length - 1) As Byte
' Create a MemoryStream.
Dim mStream As New MemoryStream(buffer)
' Write the bytes to the stream and flush it.
mStream.Write(dataBytes, 0, dataBytes.Length)
mStream.Flush()
' Create a new instance of the RSACryptoServiceProvider class
' and automatically create a new key-pair.
Dim RSAalg As New RSACryptoServiceProvider
' Export the key information to an RSAParameters object.
' You must pass true to export the private key for signing.
' However, you do not need to export the private key
' for verification.
Dim Key As RSAParameters = RSAalg.ExportParameters(True)
' Hash and sign the data.
Dim signedData As Byte() = HashAndSignBytes(mStream, Key)
' Verify the data and display the result to the
' console.
If VerifySignedHash(dataBytes, signedData, Key) Then
Console.WriteLine("The data was verified.")
Else
Console.WriteLine("The data does not match the signature.")
End If
' Close the MemoryStream.
mStream.Close()
Catch e As ArgumentNullException
Console.WriteLine("The data was not signed or verified")
End Try
End Sub
Function HashAndSignBytes(ByVal DataStream As Stream, ByVal Key As RSAParameters) As Byte()
Try
' Reset the current position in the stream to
' the beginning of the stream (0). RSACryptoServiceProvider
' can't verify the data unless the stream position
' is set to the starting position of the data.
DataStream.Position = 0
' Create a new instance of RSACryptoServiceProvider using the
' key from RSAParameters.
Dim RSAalg As New RSACryptoServiceProvider
RSAalg.ImportParameters(Key)
' Hash and sign the data. Pass a new instance of SHA256
' to specify the hashing algorithm.
Return RSAalg.SignData(DataStream, SHA256.Create())
Catch e As CryptographicException
Console.WriteLine(e.Message)
Return Nothing
End Try
End Function
Function VerifySignedHash(ByVal DataToVerify() As Byte, ByVal SignedData() As Byte, ByVal Key As RSAParameters) As Boolean
Try
' Create a new instance of RSACryptoServiceProvider using the
' key from RSAParameters.
Dim RSAalg As New RSACryptoServiceProvider
RSAalg.ImportParameters(Key)
' Verify the data using the signature. Pass a new instance of SHA256
' to specify the hashing algorithm.
Return RSAalg.VerifyData(DataToVerify, SHA256.Create(), SignedData)
Catch e As CryptographicException
Console.WriteLine(e.Message)
Return False
End Try
End Function
End Module
설명
매개 변수는 halg
, 또는 를 HashAlgorithm수락String할 Type수 있습니다.
추가 정보
적용 대상
SignData(Byte[], Int32, Int32, Object)
지정된 해시 알고리즘을 사용하여 지정된 바이트 배열 하위 집합의 해시 값을 계산하고 결과 해시 값을 서명합니다.
public:
cli::array <System::Byte> ^ SignData(cli::array <System::Byte> ^ buffer, int offset, int count, System::Object ^ halg);
public byte[] SignData (byte[] buffer, int offset, int count, object halg);
override this.SignData : byte[] * int * int * obj -> byte[]
member this.SignData : byte[] * int * int * obj -> byte[]
Public Function SignData (buffer As Byte(), offset As Integer, count As Integer, halg As Object) As Byte()
매개 변수
- buffer
- Byte[]
해시하고 서명할 입력 데이터입니다.
- offset
- Int32
데이터 사용을 시작할 배열의 오프셋입니다.
- count
- Int32
데이터로 사용할 배열의 바이트 수입니다.
- halg
- Object
해시 값을 만드는 데 사용할 해시 알고리즘입니다.
반환
지정된 데이터의 RSA 서명입니다.
예외
halg
매개 변수가 null
인 경우
halg
매개 변수의 형식이 잘못된 경우
예제
다음 코드 예제에서는 데이터에 서명하고 확인합니다.
using namespace System;
using namespace System::Security::Cryptography;
using namespace System::Text;
array<Byte>^ HashAndSignBytes( array<Byte>^DataToSign, RSAParameters Key, int Index, int Length )
{
try
{
// Create a new instance of RSACryptoServiceProvider using the
// key from RSAParameters.
RSACryptoServiceProvider^ RSAalg = gcnew RSACryptoServiceProvider;
RSAalg->ImportParameters( Key );
// Hash and sign the data. Pass a new instance of SHA256
// to specify the hashing algorithm.
return RSAalg->SignData( DataToSign, Index, Length, SHA256::Create() );
}
catch ( CryptographicException^ e )
{
Console::WriteLine( e->Message );
return nullptr;
}
}
bool VerifySignedHash( array<Byte>^DataToVerify, array<Byte>^SignedData, RSAParameters Key )
{
try
{
// Create a new instance of RSACryptoServiceProvider using the
// key from RSAParameters.
RSACryptoServiceProvider^ RSAalg = gcnew RSACryptoServiceProvider;
RSAalg->ImportParameters( Key );
// Verify the data using the signature. Pass a new instance of SHA256
// to specify the hashing algorithm.
return RSAalg->VerifyData( DataToVerify, SHA256::Create(), SignedData );
}
catch ( CryptographicException^ e )
{
Console::WriteLine( e->Message );
return false;
}
}
int main()
{
try
{
// Create a UnicodeEncoder to convert between byte array and string.
ASCIIEncoding^ ByteConverter = gcnew ASCIIEncoding;
String^ dataString = "Data to Sign";
// Create byte arrays to hold original, encrypted, and decrypted data.
array<Byte>^originalData = ByteConverter->GetBytes( dataString );
array<Byte>^signedData;
array<Byte>^smallArray;
// Create a new instance of the RSACryptoServiceProvider class
// and automatically create a new key-pair.
RSACryptoServiceProvider^ RSAalg = gcnew RSACryptoServiceProvider;
// Export the key information to an RSAParameters object.
// You must pass true to export the private key for signing.
// However, you do not need to export the private key
// for verification.
RSAParameters Key = RSAalg->ExportParameters( true );
// Hash and sign the data. Start at the fifth offset
// only use data from the next 7 bytes.
signedData = HashAndSignBytes( originalData, Key, 5, 7 );
// The previous method only signed one segment
// of the array. Create a new array for verification
// that only holds the data that was actually signed.
//
// Initialize the array.
smallArray = gcnew array<Byte>(7);
// Copy 7 bytes starting at the 5th index to
// the new array.
Array::Copy( originalData, 5, smallArray, 0, 7 );
// Verify the data and display the result to the
// console.
if ( VerifySignedHash( smallArray, signedData, Key ) )
{
Console::WriteLine( "The data was verified." );
}
else
{
Console::WriteLine( "The data does not match the signature." );
}
}
catch ( ArgumentNullException^ )
{
Console::WriteLine( "The data was not signed or verified" );
}
}
using System;
using System.Security.Cryptography;
using System.Text;
class RSACSPSample
{
static void Main()
{
try
{
// Create a UnicodeEncoder to convert between byte array and string.
ASCIIEncoding ByteConverter = new ASCIIEncoding();
string dataString = "Data to Sign";
// Create byte arrays to hold original, encrypted, and decrypted data.
byte[] originalData = ByteConverter.GetBytes(dataString);
byte[] signedData;
byte[] smallArray;
// Create a new instance of the RSACryptoServiceProvider class
// and automatically create a new key-pair.
RSACryptoServiceProvider RSAalg = new RSACryptoServiceProvider();
// Export the key information to an RSAParameters object.
// You must pass true to export the private key for signing.
// However, you do not need to export the private key
// for verification.
RSAParameters Key = RSAalg.ExportParameters(true);
// Hash and sign the data. Start at the fifth offset
// only use data from the next 7 bytes.
signedData = HashAndSignBytes(originalData, Key, 5, 7 );
// The previous method only signed one segment
// of the array. Create a new array for verification
// that only holds the data that was actually signed.
//
// Initialize the array.
smallArray = new byte[7];
// Copy 7 bytes starting at the 5th index to
// the new array.
Array.Copy(originalData, 5 , smallArray, 0, 7);
// Verify the data and display the result to the
// console.
if(VerifySignedHash(smallArray, signedData, Key))
{
Console.WriteLine("The data was verified.");
}
else
{
Console.WriteLine("The data does not match the signature.");
}
}
catch(ArgumentNullException)
{
Console.WriteLine("The data was not signed or verified");
}
}
public static byte[] HashAndSignBytes(byte[] DataToSign, RSAParameters Key, int Index, int Length)
{
try
{
// Create a new instance of RSACryptoServiceProvider using the
// key from RSAParameters.
RSACryptoServiceProvider RSAalg = new RSACryptoServiceProvider();
RSAalg.ImportParameters(Key);
// Hash and sign the data. Pass a new instance of SHA256
// to specify the hashing algorithm.
return RSAalg.SignData(DataToSign,Index,Length, SHA256.Create());
}
catch(CryptographicException e)
{
Console.WriteLine(e.Message);
return null;
}
}
public static bool VerifySignedHash(byte[] DataToVerify, byte[] SignedData, RSAParameters Key)
{
try
{
// Create a new instance of RSACryptoServiceProvider using the
// key from RSAParameters.
RSACryptoServiceProvider RSAalg = new RSACryptoServiceProvider();
RSAalg.ImportParameters(Key);
// Verify the data using the signature. Pass a new instance of SHA256
// to specify the hashing algorithm.
return RSAalg.VerifyData(DataToVerify, SHA256.Create(), SignedData);
}
catch(CryptographicException e)
{
Console.WriteLine(e.Message);
return false;
}
}
}
Imports System.Security.Cryptography
Imports System.Text
Module RSACSPExample
Sub Main()
Try
' Create a UnicodeEncoder to convert between byte array and string.
Dim ByteConverter As New ASCIIEncoding
Dim dataString As String = "Data to Sign"
' Create byte arrays to hold original, encrypted, and decrypted data.
Dim originalData As Byte() = ByteConverter.GetBytes(dataString)
Dim signedData() As Byte
Dim smallArray() As Byte
' Create a new instance of the RSACryptoServiceProvider class
' and automatically create a new key-pair.
Dim RSAalg As New RSACryptoServiceProvider
' Export the key information to an RSAParameters object.
' You must pass true to export the private key for signing.
' However, you do not need to export the private key
' for verification.
Dim Key As RSAParameters = RSAalg.ExportParameters(True)
' Hash and sign the data. Start at the fifth offset
' only use data from the next 7 bytes.
signedData = HashAndSignBytes(originalData, Key, 5, 7)
' The previous function only signed one segment
' of the array. Create a new array for verification
' that only holds the data that was actually signed.
'
' Initialize the array.
smallArray = New Byte(6) {}
' Copy 7 bytes starting at the 5th index to
' the new array.
Array.Copy(originalData, 5, smallArray, 0, 7)
' Verify the data and display the result to the
' console.
If VerifySignedHash(smallArray, signedData, Key) Then
Console.WriteLine("The data was verified.")
Else
Console.WriteLine("The data does not match the signature.")
End If
Catch e As ArgumentNullException
Console.WriteLine("The data was not signed or verified")
End Try
End Sub
Function HashAndSignBytes(ByVal DataToSign() As Byte, ByVal Key As RSAParameters, ByVal Index As Integer, ByVal Length As Integer) As Byte()
Try
' Create a new instance of RSACryptoServiceProvider using the
' key from RSAParameters.
Dim RSAalg As New RSACryptoServiceProvider
RSAalg.ImportParameters(Key)
' Hash and sign the data. Pass a new instance of SHA256
' to specify the hashing algorithm.
Return RSAalg.SignData(DataToSign, Index, Length, SHA256.Create())
Catch e As CryptographicException
Console.WriteLine(e.Message)
Return Nothing
End Try
End Function
Function VerifySignedHash(ByVal DataToVerify() As Byte, ByVal SignedData() As Byte, ByVal Key As RSAParameters) As Boolean
Try
' Create a new instance of RSACryptoServiceProvider using the
' key from RSAParameters.
Dim RSAalg As New RSACryptoServiceProvider
RSAalg.ImportParameters(Key)
' Verify the data using the signature. Pass a new instance of SHA256
' to specify the hashing algorithm.
Return RSAalg.VerifyData(DataToVerify, SHA256.Create(), SignedData)
Catch e As CryptographicException
Console.WriteLine(e.Message)
Return False
End Try
End Function
End Module
설명
이 메서드는 메서드를 사용하여 VerifyData 확인된 디지털 서명을 만듭니다.
매개 변수는 halg
, 또는 를 HashAlgorithm수락String할 Type수 있습니다. 문자열 값은 다음 중 하나일 수 있습니다.
사용할 해시 알고리즘의 OID(개체 식별자) 식별자입니다. 암호화 구성 파일에 등록된 이름 또는 Crypto API OID 테이블에 있는 이름입니다.
OID 값입니다. OID는 Crypto API에서 인식되는 OID여야 합니다.
예를 들어 SignData(new byte[5], "1.3.14.3.2.26") 또는 SignData(new byte[5], "sha1") 또는 SignData(new byte[5], "SHA1")를 사용할 수 있습니다.
추가 정보
적용 대상
.NET