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类或类而不是SHA512MD5类。 仅用于 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)

适用于

另请参阅