Share via


MD5 类

定义

表示 MD5 哈希算法的所有实现均从中继承的抽象类。

public ref class MD5 abstract : System::Security::Cryptography::HashAlgorithm
[System.Runtime.Versioning.UnsupportedOSPlatform("browser")]
public abstract class MD5 : System.Security.Cryptography.HashAlgorithm
public abstract class MD5 : System.Security.Cryptography.HashAlgorithm
[System.Runtime.InteropServices.ComVisible(true)]
public abstract class MD5 : System.Security.Cryptography.HashAlgorithm
[<System.Runtime.Versioning.UnsupportedOSPlatform("browser")>]
type MD5 = class
    inherit HashAlgorithm
type MD5 = class
    inherit HashAlgorithm
[<System.Runtime.InteropServices.ComVisible(true)>]
type MD5 = class
    inherit HashAlgorithm
Public MustInherit Class MD5
Inherits HashAlgorithm
继承
派生
属性

注解

哈希函数将任意长度的二进制字符串映射到固定长度的小型二进制字符串。 加密哈希函数具有 属性,在计算上无法找到两个哈希为同一值的不同输入;也就是说,如果相应的数据也匹配,则两组数据的哈希应匹配。 对数据的微小更改会导致哈希中出现大量不可预知的更改。

算法的 MD5 哈希大小为 128 位。

ComputeHash类的方法MD5以 16 字节数组的形式返回哈希。 请注意,某些 MD5 实现生成 32 个字符的十六进制格式哈希。 若要与此类实现互操作,请将方法的 ComputeHash 返回值格式化为十六进制值。

注意

由于 MD5/SHA1 的冲突问题,Microsoft 建议使用 SHA256 或 SHA512。 请考虑使用 SHA256 类或 SHA512 类而不是 MD5 类。 仅用于 MD5 与旧应用程序和数据的兼容性。

构造函数

MD5()

初始化 MD5 的新实例。

字段

HashSizeInBits

MD5 算法生成的哈希大小(以位为单位)。

HashSizeInBytes

MD5 算法生成的哈希大小(以字节为单位)。

HashSizeValue

表示计算所得的哈希代码的大小(以位为单位)。

(继承自 HashAlgorithm)
HashValue

表示计算所得的哈希代码的值。

(继承自 HashAlgorithm)
State

表示哈希计算的状态。

(继承自 HashAlgorithm)

属性

CanReuseTransform

获取一个值,该值指示是否可重复使用当前转换。

(继承自 HashAlgorithm)
CanTransformMultipleBlocks

当在派生类中重写时,获取一个值,该值指示是否可以转换多个块。

(继承自 HashAlgorithm)
Hash

获取计算所得的哈希代码的值。

(继承自 HashAlgorithm)
HashSize

获取计算所得的哈希代码的大小(以位为单位)。

(继承自 HashAlgorithm)
InputBlockSize

当在派生类中重写时,获取输入块的大小。

(继承自 HashAlgorithm)
OutputBlockSize

当在派生类中重写时,获取输出块的大小。

(继承自 HashAlgorithm)

方法

Clear()

释放 HashAlgorithm 类使用的所有资源。

(继承自 HashAlgorithm)
ComputeHash(Byte[])

计算指定字节数组的哈希值。

(继承自 HashAlgorithm)
ComputeHash(Byte[], Int32, Int32)

计算指定字节数组的指定区域的哈希值。

(继承自 HashAlgorithm)
ComputeHash(Stream)

计算指定 Stream 对象的哈希值。

(继承自 HashAlgorithm)
ComputeHashAsync(Stream, CancellationToken)

异步计算指定 Stream 对象的哈希值。

(继承自 HashAlgorithm)
Create()

创建 MD5 哈希算法的默认实现的实例。

Create(String)
已过时.

创建 MD5 哈希算法的指定实现的实例。

Dispose()

释放 HashAlgorithm 类的当前实例所使用的所有资源。

(继承自 HashAlgorithm)
Dispose(Boolean)

释放由 HashAlgorithm 占用的非托管资源,还可以另外再释放托管资源。

(继承自 HashAlgorithm)
Equals(Object)

确定指定对象是否等于当前对象。

(继承自 Object)
GetHashCode()

作为默认哈希函数。

(继承自 Object)
GetType()

获取当前实例的 Type

(继承自 Object)
HashCore(Byte[], Int32, Int32)

当在派生类中重写时,将写入对象的数据路由到哈希算法以计算哈希值。

(继承自 HashAlgorithm)
HashCore(ReadOnlySpan<Byte>)

将写入对象的数据路由到哈希算法以计算哈希值。

(继承自 HashAlgorithm)
HashData(Byte[])

使用 MD5 算法计算数据的哈希。

HashData(ReadOnlySpan<Byte>)

使用 MD5 算法计算数据的哈希。

HashData(ReadOnlySpan<Byte>, Span<Byte>)

使用 MD5 算法计算数据的哈希。

HashData(Stream)

使用 MD5 算法计算流的哈希。

HashData(Stream, Span<Byte>)

使用 MD5 算法计算流的哈希。

HashDataAsync(Stream, CancellationToken)

使用 MD5 算法异步计算流的哈希。

HashDataAsync(Stream, Memory<Byte>, CancellationToken)

使用 MD5 算法异步计算流的哈希。

HashFinal()

在派生类中重写时,在加密哈希算法处理最后一个数据后结束哈希计算。

(继承自 HashAlgorithm)
Initialize()

将哈希算法重置为其初始状态。

(继承自 HashAlgorithm)
MemberwiseClone()

创建当前 Object 的浅表副本。

(继承自 Object)
ToString()

返回表示当前对象的字符串。

(继承自 Object)
TransformBlock(Byte[], Int32, Int32, Byte[], Int32)

计算输入字节数组指定区域的哈希值,并将输入字节数组指定区域复制到输出字节数组的指定区域。

(继承自 HashAlgorithm)
TransformFinalBlock(Byte[], Int32, Int32)

计算指定字节数组的指定区域的哈希值。

(继承自 HashAlgorithm)
TryComputeHash(ReadOnlySpan<Byte>, Span<Byte>, Int32)

尝试计算指定字节数组的哈希值。

(继承自 HashAlgorithm)
TryHashData(ReadOnlySpan<Byte>, Span<Byte>, Int32)

尝试使用 MD5 算法计算数据的哈希。

TryHashFinal(Span<Byte>, Int32)

在哈希算法处理最后一个数据后,尝试结束哈希计算。

(继承自 HashAlgorithm)

显式接口实现

IDisposable.Dispose()

释放由 HashAlgorithm 占用的非托管资源,还可以另外再释放托管资源。

(继承自 HashAlgorithm)

适用于

另请参阅