合作机构:阿里云 / 腾讯云 / 亚马逊云 / DreamHost / NameSilo / INWX / GODADDY / 百度统计
最近,项目中做了一些安全性要求的整改。而加密是使用过程中常用的手段之一。这里简单的整理下,希望对小伙伴有帮助。
加密是一种将原始信息(明文)转换成难以被直接理解的形式(密文)的过程,
其主要目的是为了保护信息的安全和隐私。主要应用于以下场景:
(1) 适用场景
MD5 作为一种广泛使用的哈希函数,主要用于以下场景:
(2) 功能特性
(3) 原理及流程图
MD5 算法将输入的消息经过填充、分段、循环处理等步骤,最终生成一个128位的哈希值。
用字符串"Hello"的加密过程说明 MD5 算法的基本处理流程:
1. 原始输入(明文)
|
|(转换为二进制)
V
2. 二进制数据 "Hello"
|
|(填充到512位的倍数)
V
3. 填充后的二进制数据
|
|(添加原始长度的64位表示)
V
4. 长度附加后的二进制数据
|
|(分割成512位的消息块)
V
5. 消息块1 ... 消息块n
|
|(每块512位,共16个32位字)
V
6. 初始MD5值(ABCD)
|
|(通过主循环处理每个块)
V
7. 主循环(每块16步)
|_________|_________|
| | |
V V V
8. 经过F, G, H, I函数的32位字
|_________|_________|
| | |
V V V
9. 更新后的MD5值
|
V
10. 最终MD5散列值(128位)
TOP