首页 > 其他分享 >md5

md5

时间:2023-03-04 15:33:59浏览次数:52  
标签:填充 16 64 bit block md5

MD5

简介

MD5消息摘要算法(英语:MD5 Message-Digest Algorithm),一种被广泛使用的密码散列函数,可以产生出一个128位(16个字符(BYTES))的散列值(hash value),用于确保信息传输完整一致。

1996年后被证实存在弱点,可以被加以破解,对于需要高度安全性的资料,专家一般建议改用其他算法,如SHA-2。2004年,证实MD5算法无法防止碰撞攻击,因此不适用于安全性认证,如SSL公开密钥认证或是数字签名等用途。

实现过程

md5强化

首先将消息扩充为512bit(64byte)的整数倍。填充规则为:

在要处理的信息x的二进制表示之后先填入一个1,然后再添加若干个0(不超过511bit),使得message digest的bit长度是512的整数倍少64bit,最后再最低的64bit中填入消息x的比特长度的二进制表示。

以上是密码学教科书中的md5强化的方法。

那么很容易得到填充的模式是这样的。

image-20230304131742601但是当你这样去填充的过程中,你会发现消息的bit长度的填充会存在一些问题。

譬如有这样的一个message digest ”abc“,其 bit长度为24,16进制表示为0x18;那么我们以人的思维去填充那么必然是这样的0 0 0 0 0 0 0 18 ,但是这样是错误的。因为这根本就不是真正的填充方式。


在关于md5 hash函数的rfc文档中有这么几句:

  • In this document a "word" is a 32-bit quantity and a "byte" is an eight-bit quantity. A sequence of bits can be interpreted in a natural manner as a sequence of bytes, where each consecutive group of eight bits is interpreted as a byte with the high-order (mostsignificant) bit of each byte listed first. Similarly, a sequence of bytes can be interpreted as a sequence of 32-bit words, where each consecutive group of four bytes is interpreted as a word with the low-order (least significant) byte given first.
  • A 64-bit representation of b (the length of the message before the padding bits were added) is appended to the result of the previous step. In the unlikely event that b is greater than 2^64, then only the low-order 64 bits of b are used. (These bits are appended as two 32-bit words and appended low-order word first in accordance with the previous conventions.)

那么就很明显了,在md5的计算中的,其word是从低字节到高字节的(其实这里也就是跨字节的小端序,至于为什么这里要采用小端序的方式来填充bit长度,其实我不是很清楚,就我个人的理解应该是为了后面步骤中的将512bit的block划分为多个32bit的block,因为在md5中其他的跨字节常量在计算机中存的都是小端序,此处采用小端序的顺序来存储方便后续的计算)

故真正的填充顺序为(上个例子) -> 18 0 0 0 0 0 0 0

以上表示填充方式了,简单的说一下就是先填充1bit,然后疯狂的添加0bit,直到$len(message\ digest) \mod 64 = 56 $即可开始填充比特长度。

md5 MainLoop

首先将message digest中的一个512bit的block划分为多个32bit的block;具体的方式如下:

首先在md5中存在初始量A, B, C, D;其长度均为32bit,以计算机小端序的眼光来看的话,那么其存储的顺序为a[0], a[1], a[2], a[3](a[0]为低有效位);那么在对应的md5的计算中a[0]必然对应一位message digest中的值,当然也就是每个32bit block的最前面的1 byte。但是这是在memory中,所以转化为正常的数字表示,那么32bit block也就需要reverse一下,以32bit中的最后一位为最高位,第一位为最低位。故转化式子为\(m[3] << 24 + m[2] << 16 + m[1] << 8 + m[0]\) (m为32bit block)。

接下来就是4 * 16/圈的循环了。当然在这之前需要一些function&constant;

\[F(x, y, z) = (x \wedge y) \vee (\overline{x} \wedge z) \]

\[G(x,y,z) = (x \wedge z)\vee(y \wedge \overline{z}) \]

\[H(x, y, z) = x \oplus y \oplus z \]

\[I(x, y, z) = y \oplus (x \vee \overline{z}) \]

\[A_0 = 0x67452301, B_0 = 0xefcdab89, C_0 = 0x98badcfe, D_0 = 0x10325476 \]

\[64轮常数:k[i] = 2 ^ {32} * abs(sin(i + 1)) \]

自此,便可以开始进行64轮操作了

// A, B, C, D 为常量
var (
	ra, rb, rc, rd int
    // 循环左移的长度
    r [64]int = [64]int{7, 12, 17, 22,  7, 12, 17, 22,  7, 12, 17, 22,  7, 12, 17, 22,
                       5,  9, 14, 20,  5,  9, 14, 20,  5,  9, 14, 20,  5,  9, 14, 20,
                        4, 11, 16, 23,  4, 11, 16, 23,  4, 11, 16, 23,  4, 11, 16, 23,
                        6, 10, 15, 21,  6, 10, 15, 21,  6, 10, 15, 21,  6, 10, 15, 21
                       }
)
ra, rb, rc, rd = A, B, C, D

func MainLoop(w []uint32) {
    var f, g uint32
    a, b, c, d = ra, rb, rc, rd
    for i := 0; i < 64; i++ {
        switch {
        case i < 16:
            f, g = F(b, c, d), i
        case i < 32:
            f, g = G(b, c, d), (5 * i + 1) % 16
        case i < 48:
            f, g = H(b, c, d), (3 * i + 5) % 16
        default:
            f, g = I(b, c, d), (7 * i) % 16
        }
        temp := d
        d = c
        c = b
        b = leftrotate((a + f + k[i] + w[g]), r[i]) + b
        a = temp
    }
    ra, rb, rc, rd = ra + a, rb + b, rc + c, rd + d
}

func leftrotate(a, n uint32) uint32 {
    return (a >> (32 - n) | a << n)
}

如此循环完所有的512 bit block便可以计算出对应的MD5散列值,就是\(ra, rb, rc, rd\)在内存中的按小端序排列的值,写一个格式化函数即可实现。

参考文献

标签:填充,16,64,bit,block,md5
From: https://www.cnblogs.com/hellozmc/p/17178370.html

相关文章

  • c#MD5加密
    usingSystem.TextusingSystem.Security.Cryptography; stringmd5string=“123456”;MD5md5=newMD5CryptoServiceProvider();byte[]bytes1=......
  • MD5加密
    //MD5的用途?//1防篡改://发个文档,事先给别人一个MD5,是文档的摘要,//源代码管理器svn--即使电脑断网了,文件有任何改动都能被发现--本地存了一个文件的MD5--文件有更新,就再......
  • 四、文件上传系列-计算文件MD5值
    根据业务需要,在上传文件前我们要读取文件的md5值,将md5值传给后端用作秒传和断点续传文件的唯一标识。那么前端就需要使用js获取文件的md5值,对于普通小文件可以很轻松的读取......
  • Android Studio获取MD5、SHA1
    很多的时候都需要获取Android的MD5、SHA1值,像高德、百度地图就是例子需要这个值做密钥。下面Androidstudio工具获取方法1、点击studio面板右上角Gradle,找到app>Tas......
  • linux 和 windows下计算文件的MD5/SHA256/SHA1值
    一、Windows在命令行下,可以使用Windows自带的certutil命令来计算一个文件的校验值:certutil支持的算法有:MD2MD4MD5SHA1SHA256SHA384SHA512。certutil的使用方法非常......
  • MD5算法原理
    1、数据填充对消息进行数据填充,使消息的长度对512取模得448,设消息长度为X,即满足Xmod512=448。根据此公式得出需要填充的数据长度。填充方法:在消息后面进行填充,填充第一......
  • MD5用途
    1.防止被篡改:1)比如发送一个电子文档,发送前,我先得到MD5的输出结果a。然后在对方收到电子文档后,对方也得到一个MD5的输出结果b。如果a与b一样就代表中途未被篡改。2)比如我......
  • MD5加密
    因为我使用的是Maven,所以要写入坐标1<dependency>2<groupId>commons-codec</groupId>3<artifactId>commons-codec</artifactId>4<version>1.6......
  • Web安全入门与靶场实战(34)- MD5与Hash加密
    在上篇博文中,我们通过查询MySQL数据库获取到了网站的管理员账号以及经过加密后的密码,大部分情况下,数据库中的密码都是采用的MD5加密。虽然Drupal这里采用的加密方式并不是MD......
  • 80、商城业务---认证服务---MD5&盐值
    我们不能直接将密码明文存入数据库,要进行加密。可以使用Spring家的BCryptPasswordEncoder进行加密,他会将密码的明文加密成密文,并且每次获得的密文都不一样,但是再次通过明......