HashAlgorithm 클래스
정의
중요
일부 정보는 릴리스되기 전에 상당 부분 수정될 수 있는 시험판 제품과 관련이 있습니다. Microsoft는 여기에 제공된 정보에 대해 어떠한 명시적이거나 묵시적인 보증도 하지 않습니다.
모든 암호화 해시 알고리즘의 구현이 파생되어야 하는 기본 클래스를 나타냅니다.
public ref class HashAlgorithm abstract : IDisposable, System::Security::Cryptography::ICryptoTransform
public ref class HashAlgorithm abstract : IDisposable
public ref class HashAlgorithm abstract : System::Security::Cryptography::ICryptoTransform
public abstract class HashAlgorithm : IDisposable, System.Security.Cryptography.ICryptoTransform
public abstract class HashAlgorithm : IDisposable
public abstract class HashAlgorithm : System.Security.Cryptography.ICryptoTransform
[System.Runtime.InteropServices.ComVisible(true)]
public abstract class HashAlgorithm : System.Security.Cryptography.ICryptoTransform
type HashAlgorithm = class
interface IDisposable
interface ICryptoTransform
type HashAlgorithm = class
interface IDisposable
type HashAlgorithm = class
interface ICryptoTransform
interface IDisposable
[<System.Runtime.InteropServices.ComVisible(true)>]
type HashAlgorithm = class
interface ICryptoTransform
interface IDisposable
[<System.Runtime.InteropServices.ComVisible(true)>]
type HashAlgorithm = class
interface IDisposable
interface ICryptoTransform
Public MustInherit Class HashAlgorithm
Implements ICryptoTransform, IDisposable
Public MustInherit Class HashAlgorithm
Implements IDisposable
Public MustInherit Class HashAlgorithm
Implements ICryptoTransform
- 상속
-
HashAlgorithm
- 파생
- 특성
- 구현
예제
다음 코드 예제에서는 배열에 SHA256 대한 해시를 계산합니다. 이 예제에서는 미리 정의된 바이트 배열 dataArray[]
이 있다고 가정합니다.
SHA256 는 의 파생 클래스입니다 HashAlgorithm.
HashAlgorithm^ sha = SHA256::Create();
array<Byte>^ result = sha->ComputeHash( dataArray );
HashAlgorithm sha = SHA256.Create();
byte[] result = sha.ComputeHash(dataArray);
Dim sha As SHA256 = SHA256.Create()
Dim result As Byte() = sha.ComputeHash(dataArray)
설명
해시 함수는 최신 암호화의 기본 요소입니다. 이러한 함수는 임의 길이의 이진 문자열을 해시 값이라고 하는 고정 길이의 작은 이진 문자열에 매핑합니다. 암호화 해시 함수에는 동일한 값에 해시된 두 개의 고유 입력을 찾기 위해 계산적으로 불가능한 속성이 있습니다. 해시 함수는 디지털 서명과 함께 데이터 무결성에 주로 사용됩니다.
많은 양의 데이터를 나타내는 고정 된 크기의 고유 값으로 해시가 됩니다. 해당 데이터도 일치하는 경우 두 데이터 집합의 해시가 일치해야 합니다. 데이터 결과 해시 예측할 수 없는 큰 변화를 하려면 약간 변경 합니다.
SHA1과의 충돌 문제 때문에, Microsoft에서는 SHA256 이상을 기반으로 하는 보안 모델을 권장합니다.
구현자 참고
클래스에서 상속하는 HashAlgorithm 경우 및 HashFinal()멤버 HashCore(Byte[], Int32, Int32) 를 재정의해야 합니다.
생성자
HashAlgorithm() |
HashAlgorithm 클래스의 새 인스턴스를 초기화합니다. |
필드
HashSizeValue |
계산된 해시 코드의 크기(비트)를 나타냅니다. |
HashValue |
계산된 해시 코드의 값을 나타냅니다. |
State |
해시 계산의 상태를 나타냅니다. |
속성
CanReuseTransform |
현재 변형을 다시 사용할 수 있는지 여부를 나타내는 값을 가져옵니다. |
CanTransformMultipleBlocks |
파생 클래스에서 재정의된 경우 여러 개의 블록을 변형할 수 있는지 여부를 나타내는 값을 가져옵니다. |
Hash |
계산된 해시 코드의 값을 가져옵니다. |
HashSize |
계산된 해시 코드의 크기(비트 단위)를 가져옵니다. |
InputBlockSize |
파생 클래스에 재정의된 경우 입력 블록 크기를 가져옵니다. |
OutputBlockSize |
파생 클래스에 재정의된 경우 출력 블록 크기를 가져옵니다. |
메서드
Clear() |
HashAlgorithm 클래스에서 사용하는 모든 리소스를 해제합니다. |
ComputeHash(Byte[]) |
지정된 바이트 배열에 대해 해시 값을 계산합니다. |
ComputeHash(Byte[], Int32, Int32) |
지정된 바이트 배열의 지정된 영역에 대해 해시 값을 계산합니다. |
ComputeHash(Stream) |
지정된 Stream 개체에 대해 해시 값을 계산합니다. |
ComputeHashAsync(Stream, CancellationToken) |
지정된 Stream 개체에 대해 비동기적으로 해시 값을 계산합니다. |
Create() |
사용되지 않음.
사용되지 않음.
해시 알고리즘의 기본 구현 인스턴스를 만듭니다. |
Create(String) |
사용되지 않음.
해시 알고리즘의 지정된 구현의 인스턴스를 만듭니다. |
Dispose() |
HashAlgorithm 클래스의 현재 인스턴스에서 사용하는 모든 리소스를 해제합니다. |
Dispose(Boolean) |
HashAlgorithm에서 사용하는 관리되지 않는 리소스를 해제하고, 관리되는 리소스를 선택적으로 해제할 수 있습니다. |
Equals(Object) |
지정된 개체가 현재 개체와 같은지 확인합니다. (다음에서 상속됨 Object) |
GetHashCode() |
기본 해시 함수로 작동합니다. (다음에서 상속됨 Object) |
GetType() |
현재 인스턴스의 Type을 가져옵니다. (다음에서 상속됨 Object) |
HashCore(Byte[], Int32, Int32) |
파생 클래스에 재정의된 경우 개체에 쓰여진 데이터의 경로를 해시를 계산할 해시 알고리즘에 지정합니다. |
HashCore(ReadOnlySpan<Byte>) |
개체에 쓴 데이터를 해시를 계산하기 위한 해시 알고리즘으로 경로 처리합니다. |
HashFinal() |
파생 클래스에서 재정의된 경우 암호화 해시 알고리즘에서 마지막 데이터를 처리한 후 해시 계산을 완료합니다. |
Initialize() |
해시 알고리즘을 초기 상태로 다시 설정합니다. |
MemberwiseClone() |
현재 Object의 단순 복사본을 만듭니다. (다음에서 상속됨 Object) |
ToString() |
현재 개체를 나타내는 문자열을 반환합니다. (다음에서 상속됨 Object) |
TransformBlock(Byte[], Int32, Int32, Byte[], Int32) |
입력 바이트 배열의 지정된 영역에 대한 해시 값을 계산하여 입력 바이트 배열의 지정된 영역을 출력 바이트 배열의 지정된 영역에 복사합니다. |
TransformFinalBlock(Byte[], Int32, Int32) |
지정된 바이트 배열의 지정된 영역에 대해 해시 값을 계산합니다. |
TryComputeHash(ReadOnlySpan<Byte>, Span<Byte>, Int32) |
지정된 바이트 배열의 해시 값을 계산하려고 시도합니다. |
TryHashFinal(Span<Byte>, Int32) |
해시 알고리즘에서 마지막 데이터를 처리한 후 해시 계산을 완료하려고 시도합니다. |
명시적 인터페이스 구현
IDisposable.Dispose() |
HashAlgorithm에서 사용하는 관리되지 않는 리소스를 해제하고, 관리되는 리소스를 선택적으로 해제할 수 있습니다. |
적용 대상
추가 정보
.NET